Quantum Circuit Designs of Integer Division Optimizing T-count and
  T-depth by Thapliyal, Himanshu et al.
ar
X
iv
:1
80
9.
09
73
2v
1 
 [q
ua
nt-
ph
]  
25
 Se
p 2
01
8
1
Quantum Circuit Designs of Integer Division
Optimizing T-count and T-depth
Himanshu Thapliyal∗, Edgard Mun˜oz-Coreas∗, T. S. S. Varun∗, and Travis S. Humble†
Abstract—Quantum circuits for mathematical functions such
as division are necessary to use quantum computers for scientific
computing. Quantum circuits based on Clifford+T gates can
easily be made fault-tolerant but the T gate is very costly to
implement. The small number of qubits available in existing
quantum computers adds another constraint on quantum cir-
cuits. As a result, reducing T-count and qubit cost have become
important optimization goals. The design of quantum circuits
for integer division has caught the attention of researchers and
designs have been proposed in the literature. However, these
designs suffer from excessive T gate and qubit costs. Many of
these designs also produce significant garbage output resulting in
additional qubit and T gate costs to eliminate these outputs. In
this work, we propose two quantum integer division circuits.
The first proposed quantum integer division circuit is based
on the restoring division algorithm and the second proposed
design implements the non-restoring division algorithm. Both
proposed designs are optimized in terms of T-count, T-depth
and qubits. Both proposed quantum circuit designs are based
on (i) a quantum subtractor, (ii) a quantum adder-subtractor
circuit, and (iii) a novel quantum conditional addition circuit.
Our proposed restoring division circuit achieves average T-count
savings from 79.03% to 91.69% compared to the existing works.
Our proposed non-restoring division circuit achieves average T-
count savings from 49.75% to 90.37% compared to the existing
works. Further, both our proposed designs have linear T-depth.
I. INTRODUCTION
Among the emerging computing paradigms, quantum com-
puting appears promising due to its applications in number
theory, encryption, search and scientific computation [1] [2].
Quantum circuits for integer arithmetic operations such as
addition, subtraction, multiplication and division are required
in the quantum circuit implementations of many quantum
algorithms in these areas. Quantum arithmetic circuits for
division can be used in the circuit implementation of quantum
algorithms such as those for computing shifted quadratic
character problems, principal ideal problems and hidden shift
problems [2] [3] [4]. Quantum division circuits also reduce the
resources needed in the circuit implementations of higher level
functions such as calculating the greatest common divisor via
the Euclidean algorithm. An efficient quantum circuit for the
Euclidean algorithm has use in quantum algorithms such as
those for solving the shifted multiplicative character problem
[4]. Thus, researchers have included dedicated libraries of
∗ Himanshu Thapliyal, Edgard Mun˜oz-Coreas, T. S. S. Varun are with the
Department of Electrical and Computer Engineering, University of Kentucky,
Lexington, KY, USA.
Email :hthapliyal@uky.edu
† Travis S. Humble is with the Quantum Computing Institute, Oak Ridge
National Laboratory, TN, USA.
basic quantum integer arithmetic functions such as division
in quantum programming languages such as Quipper and
LIQUi|〉 and in quantum computing design tools [1] [5].
Quantum computation can be performed on quantum cir-
cuits built from quantum gates. Any constant inputs in the
quantum circuit are called ancillae. Garbage outputs are any
outputs which exist in the quantum circuit to preserve one-to-
one mapping but are neither one of the primary inputs nor a
useful output. The inputs regenerated at the outputs are not
considered garbage outputs [6]. Ancillae and garbage outputs
are circuit overhead that need to be minimized.
The fault-tolerant implementation of quantum circuits is
gaining the attention of researchers because physical quantum
computers are prone to noise errors [7]. Fault-tolerant imple-
mentations of quantum gates and quantum error correcting
codes can be used to overcome the limits imposed by noise
errors in implementing quantum computing [8] [9]. Recently,
researchers have implemented quantum logic gates such as
the Toffoli gate, Fredkin gate and quantum full adder with
fault-tolerant implementations of the Clifford+T gates due to
their demonstrated tolerance to noise errors [8]. However, the
increased tolerance to noise errors comes with the increased
implementation overhead associated with the quantum T gate
[10] [8] [9]. Because of the increased cost to realize the T gate,
T-count and T-depth are important performance measures for
fault-tolerant quantum circuit design.
The design of quantum circuits for integer division is an
active area of research. Designs such as those proposed in [11],
[12] and [13] present dividers that can be used in quantum
computation. The design in [11] implements the restoring
division algorithm and the designs in [12] are based on the
non-restoring division algorithm. The design presented in the
recent work in [13] uses a novel division algorithm. The design
in [11] has a significant overhead in terms of T gates because it
depends on quantum gates that cannot be exactly constructed
using Clifford+T gates. The Clifford+T gate approximations
for these gates are costly in terms of T-count [14]. Further,
the T-count increases as the accuracy of the approximation
of these gates is improved [14]. In contrast the dividers in
[12] depend on quantum gates that can be exactly realized
with Clifford+T gates. At most 7 T gates are required to
implement each logic gate in [12]. Thus, the designs in [12]
require significantly fewer T gates than the design presented in
[11]. However, the designs in [12] produce significant garbage
output. Thus, the dividers in [12] will have additional ancillae
and T gate overhead from removing these garbage outputs. A
recent design presented in [13] also depends on quantum gates
that can be exactly realized with Clifford+T gates. However,
2the design methodology presented in [13] generates a quantum
circuit that suffers from significant T gate and qubit cost
overhead. In addition, the design in [13] produces significant
garbage output. Thus, the divider in [13] will have additional
ancillae and T gate overhead from removing these garbage
outputs.
To address the shortcomings of the existing work this paper
presents two designs for quantum circuit integer division based
on Clifford+T gates. The first proposed quantum circuit is
based on the restoring division algorithm and the second
proposed quantum circuit is based on the non-restoring di-
vision algorithm. Both proposed quantum integer division
circuits are based on: (i) a quantum subtractor, (ii) a quantum
adder-subtractor circuit, and (iii) a novel quantum conditional
addition circuit. The preliminary version of this paper is avail-
able in [15], [16]. The proposed quantum restoring division
circuit has quadratic T-count, linear T-depth and requires 3 ·n
qubits (where n is the size of the inputs). The proposed non-
restoring division circuit has quadratic T-count, linear T-depth
and requires 3 ·n−1 qubits (where n is the size of the inputs).
This paper is organized as follows: Section II discusses the
Clifford+T gate set, background on resource cost measures,
the quantum subtractor, quantum adder-subtractor circuit and
the novel quantum conditional addition circuit. The proposed
quantum restoring integer division circuit is presented in
Section III while the comparison with the existing works
is presented in Section IV. In Section V, the design of
the proposed quantum non-restoring integer division circuit
is discussed and Section VI illustrates comparison with the
existing works.
II. BACKGROUND
A. Quantum Gates
CLIFFORD+T GATE SET
Hadamard Gate
H
1√
2
[
1 1
1 −1
]
T Gate
T
[
1 0
0 ei·
pi
4
]
Hermitian of T
Gate T †
[
1 0
0 e−i·
pi
4
]
Phase Gate
S
[
1 0
0 i
]
Hermitian of
Phase Gate S†
[
1 0
0 −i
]
NOT Gate
[
0 1
1 0
]
Feynman
(CNOT) Gate
•


1 0 0 0
0 1 0 0
0 0 0 1
0 0 1 0


Fig. 1: The quantum gate set used in this work.
Fault-tolerant implementation of quantum circuits is gaining
the attention of researchers because physical quantum com-
puters are prone to noise errors [7]. Recently, researchers
have implemented quantum logic gates and circuits with fault-
tolerant implementations of the Clifford+T gate set due to its
demonstrated tolerance to noise errors [8]. Figure 1 presents
the gates that make up the Clifford+T quantum gate family.
Evaluating quantum circuit performance in terms of T-count
and T-depth is of interest to researchers because the fault-
tolerant implementation of the T gate is significantly more
costly than the fault-tolerant implementation costs of the other
Clifford+T gates [10]. The number of qubits in a quantum
circuit is a resource measure of interest because of the limited
number of qubits available on existing quantum computers
[17] [18]. We now define the T-count, T-depth and qubit cost
resource measures.
• T-count: T-count is the total number of T gates used in
the quantum circuit.
• T-depth: T-depth is the number of T gate layers in the
circuit, where a layer consists of quantum operations that
can be performed simultaneously.
• Qubit cost: Qubit cost is the total number of qubits
required to design the quantum circuit.
B. Design of Quantum Subtractor
The subtractor circuit takes two n bit inputs a and b. At
the end of computation, the input a emerges unchanged and
the input b is transformed to the difference of b from a. The
quantum subtractor calculates (b¯ + a) which is equivalent to
b−a [19]. A quantum ripple carry adder is used to realize the
quantum subtractor circuit. We use the quantum ripple carry
adder proposed in [20] for developing the quantum subtractor
circuit. We chose the ripple carry adder proposed in [20]
because this adder has been shown in the literature to be
efficient in terms of gates and has a T-depth that is constant
and independent of the circuit size n. We determined that this
quantum subtractor will have a T-count of 14 · n − 14 and a
T-depth of 10. Thus, the quantum subtraction circuit used in
our proposed dividers will have a T-count of order O(n) and
a T-depth of order O(1).
C. Design of Quantum Adder-Subtractor (Add-Sub) Circuit
The quantum adder-subtractor (Add-Sub) circuit takes two
n bit inputs a and b and a single one bit input ctrl. Operation
of the quantum Add-Sub circuit is conditioned on the value of
ctrl. When ctrl is high, the circuit calculates b−a. When the
ctrl input is low, the circuit calculates b + a. The quantum
Add-Sub calculates (b¯+ a) when ctrl is high. The expression
(b¯+ a) is equivalent to b − a. The quantum Add-Sub circuit
is based on the design presented in [19] and uses the ripple
carry adder in [20]. We determined that this quantum Add-
Sub circuit will have a T-count of 14 ·n− 14 and a T-depth of
10. Thus, the quantum Add-Sub circuit used in our proposed
dividers will have a T-count of order O(n) and a T-depth of
order O(1).
D. Design of Quantum Conditional Addition Ctrl-Add Circuit
The quantum Ctrl-Add circuit in this work is a modified
version of the Ctrl-Add circuit proposed in [21]. Operation of
3ctrl • • • • ctrl
b0 • • s0
a0 • • • a0
b1 • • s1
a1 • • • • • • • a1
b2 • • s2
a2 • • • • • • • a2
b3 s3
a3 • • • a3
Fig. 2: Circuit design of quantum Conditional Addition (Ctrl-
Add) circuit
the quantum Ctrl-Add circuit is conditioned on the value of
ctrl. When ctrl is high, the circuit calculates b+a. When ctrl
is low, the circuit performs no computation. An illustrative
example is shown in Figure 2 for two 4 qubit operands
a0 . . . a3 and b0 . . . b3. We are able to reduce the amount of
qubits and quantum gates required because we do not need
the carry out qubit in the proposed integer dividers.
We determined that our quantum Ctrl-Add circuit will have
a T-count of 21 · n − 14 and a T-depth of 2 · n. Thus, the
quantum Ctrl-Add circuit used in our proposed dividers will
have a T-count of order O(n) and a T-depth of order O(n).
III. PROPOSED DESIGN OF RESTORING QUANTUM
INTEGER DIVISION CIRCUIT
We now present our proposed restoring quantum integer
division circuit. The proposed design produces no garbage
output and has lower T-count and qubit costs compared to the
existing works. The quantum circuits used in our proposed
quantum restoring division circuit are (i) the quantum sub-
tractor and (ii) the quantum Ctrl-Add circuit. Our proposed
quantum restoring divider saves T gates by not doing compu-
tation in the QFT domain. We also base our design on the T
gate efficient quantum subtractor and the novel quantum Ctrl-
Add circuit presented in Section II. The modules used in our
quantum circuit do not produce garbage outputs and restore
inputs to their original values. Thus, we are able to save qubits
and T gates by placing these quantum circuits such that our
proposed quantum restoring division circuit will produce no
garbage outputs.
This proposed quantum integer division circuit calculates
division by implementing the restoring division algorithm. The
restoring division algorithm is illustrated in Figure 3. Prior
research has demonstrated the correctness of the restoring
division algorithm through functionally correct circuit imple-
mentations such as those in [11].
Consider the division of two n bit 2’s complement positive
binary numbers a and b. Let |B〉 be a n bit quantum register
that is initialized to the value b, let |Q〉 be a n bit quantum
register that is initialized with the value a and let |R〉 be a n bit
quantum register initialized to 0. At the end of computation,
the quantum register |B〉 will be restored to the value b
while the quantum register |R〉 will have the remainder of the
Algorithm 1: Restoring division algorithm
Function Restoring(a, b)
Requirements: a and b are positive and 2’s complement.
//Takes 2 n bit values a and b as input.
//Returns the quotient as an n bit number Q and
//the remainder from the division as an n bit
//number R.
1 R = 0n; // Where 0n are n zeros.
2 Q = an−1an−2 · · ·a1a0
3 // an−1 is the most significant bit of a.
4
5 For i = 1 to n− 1
6 Y = Rn−1−iRn−3−i · · ·R1R0Qn−1 · · ·Qn−i
7 // Where Rn−1−i is the most significant bit of Y .
8 Y = Y − b
9 If (Y < 0)
10 Y = Y + b
11 End
12 Rn−i = Rn−1−i
13 End
14
15 Q = Q− b
16 If (Q < 0)
17 Q = Q+ b;
18 End
19 R0 = Qn−1
20
21 Return Q,R
Fig. 3: The restoring division algorithm.
division of a by b. At the end of computation, the quantum
register |Q〉 will have the quotient of the division of a by b.
The proposed methodology is generic in nature and can
design a quantum restoring integer division circuit of any
size. The steps of the proposed methodology are presented
along with an illustrative example of the proposed quantum
restoring integer division circuit for the division of two 4
bit numbers a0 . . . a3 and b0 . . . b3 shown in Figure 4. The
proposed methodology is repeated n times. A quantum circuit
is generated for each step of the design.
A. Steps of the Proposed Design Methodology
The following steps of the proposed methodology are re-
peated n times. Starting with the first n− 1 iterations.
For i = 1 : 1 : n− 1:
• Step 1: This step executes line 6 and line 8 of Algorithm 1
in quantum hardware. Step 1 is shown for a 4 bit restoring
divider in Figure 4a. This step has the following two sub-
steps:
– Sub-step 1: Treat the locations |Rn−1−i〉 through
|R0〉 of quantum register |R〉 and locations |Qn−1〉
through |Qn−i〉 of quantum register |Q〉 as one
n qubit combined quantum register |Y 〉 such that
4|Q2:0〉 |Q2:0〉
|Q3〉
S
u
b
tr
ac
ti
o
n |Q3〉
|R0〉 |R0〉
|R1〉 |R1〉
|R2〉 |R2〉
|R3〉 |R3〉
|B3:0〉 • |B3:0〉
(a) after Step 1
|Q2:0〉 |Q2:0〉
|Q3〉
S
u
b
tr
ac
ti
o
n |Q3〉
|R0〉 |R0〉
|R1〉 |R1〉
|R2〉 • |R2〉
|R3〉 |R3〉
|B3:0〉 • |B3:0〉
(b) after Step 2
|Q2:0〉 |Q2:0〉
|Q3〉
S
u
b
tr
ac
ti
o
n
C
tr
l-
A
d
d
|Q3〉
|R0〉 |R0〉
|R1〉 |R1〉
|R2〉 • |R2〉
|R3〉 • |R3〉
|B3:0〉 • • |B3:0〉
(c) after Step 3
|Q2:0〉 |Q2:0〉 |Q2:0〉 |Q2:0〉
|Q3〉
S
u
b
tr
ac
ti
o
n
C
tr
l-
A
d
d
|Q3〉 |Q3〉
It
er
at
io
n
1 |Q3〉
|R0〉 |R0〉 |R0〉 |R0〉
|R1〉 |R1〉 = |R1〉 |R1〉
|R2〉 • |R2〉 |R2〉 |R2〉
|R3〉 • |R3〉 |R3〉 • |R3〉
|B3:0〉 • • |B3:0〉 |B3:0〉 • |B3:0〉
(d) after Step 4. Quantum circuit and equivalent graphical represen-
tation are shown.
Fig. 4: Circuit generation of the proposed quantum restoring
division circuit for the case of i = 1 (illustrated with a 4 bit
divider).
the values at locations |Qn−1〉 through |Qn−i〉 will
occupy locations |Yi−1〉 through |Y0〉 and locations
|Rn−1−i〉 through |R0〉 will occupy locations |Yn−1〉
through |Yi〉.
– Sub-step 2: Apply quantum register |B〉 and quantum
register |Y 〉 to the quantum subtraction circuit so
that, at the end of computation, |B〉 is unchanged
and |Y 〉 has the result of computation.
• Step 2: This step prepares register location |Rn−i〉 for use
in subsequent steps and partially completes the execution
of line 12 of Algorithm 1 in quantum hardware. Step 2
is shown for a 4 bit restoring divider in Figure 4b. At
quantum register locations |Rn−i〉 and |Yn−1〉, apply a
CNOT gate such that quantum register location |Yn−1〉
is unchanged and quantum register location |Rn−i〉 is
transformed to |Rn−i ⊕ Yn−1〉.
• Step 3: Step 3 implements lines 9 through 11 of Algo-
rithm 1 in quantum hardware. Step 3 is shown for a 4 bit
restoring divider in Figure 4c. This step has the following
two sub-steps:
– Sub-step 1: Apply the quantum registers |B〉 and |Y 〉
to a quantum Ctrl-Add circuit with no input carry
such that the quantum register |B〉 will be unchanged
and quantum register |Y 〉 will contain the result of
computation.
– Sub-step 2: Apply quantum register location |Rn−i〉
to the quantum Ctrl-Add circuit such that the opera-
tion of the Ctrl-Add circuit will be conditioned on the
value at location |Rn−i〉. Quantum register location
|Rn−i〉 is unchanged.
After this step,
• Step 4: This step completes the execution of line 12 of
Algorithm 1. Step 4 is shown for a 4 bit restoring divider
in Figure 4d. At quantum register location |Rn−i〉 apply
a quantum NOT gate. Quantum register location |Rn−i〉
now has the remainder bit rn−i of the division of a by
b.
The final iteration has the following steps:
• Step 1: This step executes line 15 of Algorithm 1 in
quantum hardware. Step 1 is shown for a 4 bit restoring
divider in Figure 4a. Apply quantum register |B〉 and
quantum register |Q〉 to the quantum subtraction circuit
so that, at the end of computation, |B〉 is unchanged and
|Q〉 has the result of computation.
• Step 2: This step prepares register location |R0〉 for use
in subsequent steps and partially completes the execution
of line 19 of Algorithm 1. Step 2 is shown for a 4
bit restoring divider in Figure 4b. At quantum register
locations |R0〉 and |Qn−1〉, apply a CNOT gate such
that quantum register location |Qn−1〉 is unchanged and
quantum register location |R0〉 shall be transformed to
the value |R0 ⊕Qn−1〉.
• Step 3: Steps 3 implements lines 16 through 18 of
Algorithm 1 in quantum hardware. Step 3 is shown for
a 4 bit restoring divider in Figure 4c. Step 3 has the
following two sub-steps:
– Sub-step 1: Apply the quantum registers |B〉 and |Q〉
to a quantum Ctrl-Add circuit with no input carry
such that the quantum register |B〉 will be unchanged
and quantum register |Q〉 will contain the result of
computation.
– Sub-step 2: Apply quantum register location |R0〉 to
the quantum Ctrl-Add circuit such that the operation
of the Ctrl-Add circuit will be conditioned on the
value at location |R0〉. Quantum register location
|R0〉 is unchanged.
After this step, quantum register |Q〉 will have the quo-
tient of the division of a and b.
• Step 4: This step completes the execution of line 19 of
Algorithm 1. Step 4 is shown for a 4 bit restoring divider
in Figure 4d. At quantum register location |R0〉 apply a
quantum NOT gate. Quantum register location |R0〉 now
has the remainder bit r0 of the division of a by b. After
this step, quantum register |R〉 now has the remainder of
the division of a and b.
Figure 5 shows the complete proposed quantum restoring
division circuit for the division of two 4 bit numbers a0 . . . a3
and b0 . . . b3.
5|Q0〉
It
er
at
io
n
4
|Q0〉
|Q1〉
It
er
at
io
n
3
|Q1〉
|Q2〉
It
er
at
io
n
2
|Q2〉
|Q3〉
It
er
at
io
n
1
|Q3〉
|R0〉 • |R0〉
|R1〉 • |R1〉
|R2〉 • |R2〉
|R3〉 • |R3〉
|B3:0〉 • • • • |B3:0〉
Fig. 5: Complete proposed quantum restoring integer divider
circuit (after all 4 iterations)
IV. COST ANALYSIS OF THE PROPOSED RESTORING
DIVISION CIRCUIT
A. T-Count Analysis
The T-count of the proposed quantum integer division
circuit is illustrated shortly for each step of the proposed
design methodology. The steps are iterated n times.
• The T-count for Step 1 is 14 · n− 14. We use a quantum
subtraction circuit of T-count 14 · n− 14 in this step.
• Steps 2 does not require T gates.
• The T-count for Step 3 is 21 · n− 14. We use a quantum
Ctrl-Add circuit of T-count 21 · n− 14 in this step.
• Steps 4 does not require T gates.
We determine the T-count for a single iteration of the
proposed design by summing the T-count for each step in the
methodology as shown below:
14 · n− 14 + 21 · n− 14 (1)
This expression can be simplified to the following:
35 · n− 28 (2)
The steps in the proposed methodology are iterated n times.
Thus the T-count for the proposed restoring division circuit is
n · (35 · n − 18) which simplifies to the expression shown
below:
35 · n2 − 28 · n (3)
B. T-Depth Analysis
The T-depth of the proposed quantum integer division
circuit is illustrated shortly for each step of the proposed
design methodology. Our proposed design is based on T-depth
efficient designs of quantum subtraction circuits and quantum
Ctrl-Add circuits. We determined that garbageless and T gate
optimized quantum subtraction circuits in the literature such
as the design in [19] have a T-depth that is constant and
independent of the circuit size n. Thus, these subtraction
circuits have T-depth of order O(1). We determined as well
that Ctrl-Add circuits in the literature such as the design in
[21] scale as a function of circuit size n. Thus, these Ctrl-Add
circuits have a T-depth of order O(n).
The T-depth of the proposed quantum integer division
circuit is illustrated shortly for each step of the proposed
design methodology. The steps are iterated n times.
• Step 1 has a constant T-depth of 10. This T-depth is seen
by locations |B1〉 through |Bn−2〉 of quantum register
|B〉. We use a quantum subtraction circuit of constant
T-depth 10 in this step (where T-depth is independent of
circuit size n).
• Step 2 does not require T gates.
• Step 3 has a T-depth of 2 · n. This T-depth is seen by
location |Rn−1−i〉 of quantum register |R〉 (where 0 ≤
i ≤ n−1). We use a quantum Ctrl-Add circuit of T-depth
2 · n in this Step.
• Step 4 does not require T gates.
We now illustrate the steps we use to determine the total
T-depth for the proposed quantum restoring integer division
circuit.
• Step 1: Calculate the total T-depth for quantum register
|B〉. We determine the T-depth for quantum register |B〉
for each step of the proposed methodology.
– Step 1: Locations |B1〉 through |Bn−2〉 of quantum
register |B〉 see 10 T gate layers.
– Step 2 does not require T gates
– Step 3: Locations |B1〉 through |Bn−2〉 of quantum
register |B〉 see 13 T gate layers.
– Step 4 does not require T gates.
Thus, quantum register |B〉 has a T-depth of 23 · n.
• Step 2: Calculate the total T-depth for quantum register
|R〉. We first consider iterations 1 through n − 1. For
iteration i (where 1 ≤ i ≤ n − 1), we determine the
T-depth for quantum register |R〉 for each step of the
proposed methodology.
– Step 1: Locations |Rn−2−i〉 through |R0〉 of quantum
register |R〉 see 4 T gate layers. After iteration n−2,
only location |R0〉 of quantum register |R〉 will see
T gate layers. In iteration n−1, |R〉 will not see any
T gate layers.
– Step 2 does not require T gates
– Step 3: Locations |Rn−i〉 sees 2 · n T gate layers
while |Rn−2−i〉 through |R0〉 of quantum register
|R〉 see 6 T gate layers. After iteration n − 2, only
locations |R2〉 and |R0〉 of quantum register |R〉 will
see T gate layers. In iteration n − 1, only location
|R1〉 will see any T gate layers.
– Step 4 does not require T gates.
Thus, a single iteration of the proposed design see a T-
depth of 2 · n on quantum register location |Rn−i〉. We
now consider the final iteration pf the proposed design:
– Step 1: No locations of quantum register |R〉 see T
gate layers.
– Step 2 does not require T gates
– Step 3: Location |R0〉 sees 2 · n T gate layers.
– Step 4 does not require T gates.
6Thus, the final iteration of the proposed design see a
T-depth of 2 · n on quantum register location |R0〉.
We calculate the total T-depth seen by each location in
register |R〉 and determined that location |R0〉 sees the
most T gate layers, a total of 12 · n− 18 T gate layers.
• Step 3: Calculate the total T-depth for quantum register
|Q〉. We first consider iterations 1 through n − 1. For
iteration i (where 1 ≤ i ≤ n − 1), we determine the
T-depth for quantum register |Q〉 for each step of the
proposed methodology.
– Step 1: Locations |Qn−1〉 through |Qn−i〉 of quan-
tum register |Q〉 see 4 T gate layers.
– Step 2 does not require T gates
– Step 3: Locations |Qn−1〉 through |Qn−i〉 of quan-
tum register |Q〉 see 6 T gate layers.
– Step 4 does not require T gates.
Thus, a single iteration of the proposed design see a T-
depth of 10 on quantum register location |Qn−1〉 through
|Qn−i〉. We now consider the final iteration of the pro-
posed design:
– Step 1: Locations |Qn−2〉 through |Q0〉 of quantum
register |Q〉 see 4 T gate layers.
– Step 2 does not require T gates
– Step 3: Locations |Qn−2〉 through |Q0〉 of quantum
register |Q〉 see 6 T gate layers.
– Step 4 does not require T gates.
Thus, the final iteration of the proposed design see a T-
depth of 10 on quantum register locations |Qn−2〉 through
|Q0〉. We calculate the total T-depth seen by each location
in register |Q〉 and determined that location |Qn−1〉 sees
the most T gate layers. Location |Qn−1〉 sees 10 · n− 8
T gate layers.
• Step 4: Determine which quantum register sees the most
T gate layers. In our proposed design the T-depth for each
quantum register is given as:
– Quantum register |Q〉 has a T-depth of 10 · n− 8.
– Quantum register |R〉 has a T-depth of 12 · n− 18.
– Quantum register |B〉 has a T-depth of 23 · n.
Quantum register |B〉 sees the most T gate layers because
23 · n > 12 · n − 18 and 23 · n > 10 · n − 8. Thus,
the T-depth for our proposed quantum restoring integer
division circuit is 23 ·n. This T-depth is seen by location
|B1〉 through |Bn−2〉 of quantum register |B〉.
C. Cost Comparison
Comparisons of the proposed design with the current state
of the art are presented in Tables I, II and III. We compare
our proposed design to the existing quantum restoring division
circuit by Khosropour et al. [11]. We also compare against
the novel design methodology presented in Dibbo et. al.
[13]. To perform the comparison of our proposed design to
the existing quantum division circuits, we implemented each
designs with Clifford+T gates. To realize reversible gates such
as the Toffoli gate, we use the Clifford+T implementations
presented in [8]. As ahown in [8], the Toffoli gate has a T-
count of 7 and a T-depth of 3. The design by Khosropour et al.
TABLE I: Comparison of Resource Count Between Proposed
and Existing Work
1 2 Proposed
T-count ≈ 400 · n2 ≈ 9 · n3 35 · n2 − 28 · n
T-depth 130 · n NA 23 · n
qubits 4 · n ≈ 1
2
n
3 + 4 · n 3 · n
1 is the design by Khosropour et al. [11]
2 is the design by Dibbo et al. [13] modified to remove garbage output.
Table entries are marked NA where a closed-form expression is not
available for the design by Dibbo et al.
TABLE II: T-count Comparison of Quantum Integer Division
Circuits
n 1 2 Proposed % Impr. % Impr.
w.r.t. 1 w.r.t. 2
4 ≈ 6400 ≈ 576 448 ≈ 93.00 ≈ 22.22
8 ≈ 25600 ≈ 4608 2016 ≈ 92.13 ≈ 56.25
16 ≈ 102400 ≈ 36864 8512 ≈ 91.69 ≈ 76.91
32 ≈ 409600 ≈ 294912 34944 ≈ 91.47 ≈ 88.15
64 ≈ 1638400 ≈ 2359296 141568 ≈ 91.36 ≈ 94.00
128 ≈ 6553600 ≈ 18874368 569856 ≈ 91.30 ≈ 96.98
256 ≈ 26214400 ≈ 150994944 2286592 ≈ 91.28 ≈ 98.49
512 ≈ 104857600 ≈ 1207959552 9160704 ≈ 91.26 ≈ 99.24
Average: 91.69 79.03
1 is the design by Khosropour et al. [11]
2 is the design by Dibbo et al. [13] modified to remove garbage output.
depends on quantum gates that cannot be accurately realized
with Clifford+T gates. For these quantum gates, we use the
Clifford+T approximations presented in [14] to calculate the
T-count. We select the approximations for these gates with
the poorest accuracy in our calculations since they have the
lowest T-count. We also apply the Bennett’s garbage removal
scheme illustrated in [22] to remove the garbage outputs from
the design by Dibbo et. al. We determined the qubit cost for the
design in Khosropour et al. by summing the qubits required for
the quotient, remainder, garbage outputs, and primary inputs.
We estimated the qubit cost for the design by Dibbo et. al.
by summing the qubits required for the quotient, remainder,
garbage outputs, and primary inputs.
1) Cost Comparison in Terms of T-count: Table I shows
that our proposed design and the design by Khosropour et
al. have T-count costs of order O(n2) while the T-count for
the design by Dibbo et al. is of order O(n3). Table II shows
TABLE III: Qubit Cost Comparison of Quantum Integer
Division Circuits
n 1 2 Proposed % Impr. % Impr.
w.r.t. 1 w.r.t. 2
4 16 ≈ 48 12 25.00 ≈ 75.00
8 32 ≈ 288 24 25.00 ≈ 91.67
16 64 ≈ 2112 48 25.00 ≈ 97.73
32 128 ≈ 16512 96 25.00 ≈ 99.42
64 256 ≈ 131328 192 25.00 ≈ 99.85
128 512 ≈ 1049088 384 25.00 ≈ 99.96
256 1024 ≈ 8389632 768 25.00 ≈ 99.99
512 2048 ≈ 67110912 1536 25.00 ≈ 99.99
Average: 25.00 93.94
1 is the design by Khosropour et al. [11]
2 is the design by Dibbo et al. [13] modified to remove garbage output.
7that our proposed design methodology achieves improvement
ratios ranging from 91.26% to 93.00% and 22.22% to 99.24%
compared to the designs by Khosropour et al. and the design
by Dibbo et al. in terms of T-count.
2) Cost Comparison in Terms of Qubits: Table I shows that
our proposed design and the design by Khosropour et al. have
qubit costs of order O(n) while the qubit cost for the design
by Dibbo et al. is of order O(n3). We also compared the
qubit cost of our proposed design methodology to the designs
presented by Khosropour et al. and Dibbo et. al. for values of
n ranging from 4 to 512 in table III. We calculated that our
proposed design methodology achieves an improvement ratio
of 25.00% compared to the design by Khosropour et al. We
determined that our proposed design achieves improvement
ratios ranging from 75.00% to 99.99% compared to the design
by Dibbo et. al.
3) Cost Comparison in Terms of T-depth: The T-depth cost
of the proposed design and designs by Khosropour et al.
and the proposed design are O(n). A closed-form T-depth
expression is not available for the design by Dibbo et al. We
calculated that the design by Khosropour et al. has a T-depth
that is 5.6 times higher than the T-depth of the proposed work.
V. PROPOSED DESIGN OF NON-RESTORING QUANTUM
INTEGER DIVISION CIRCUIT
We now present our proposed non-restoring quantum integer
division circuit. The proposed design produces no garbage
output and has lower T-count and qubit costs compared to
the existing work. The quantum circuits required to build our
proposed quantum non-restoring division circuit are (i) the
quantum subtractor, (ii) the quantum Add-Sub circuit and (iii)
the quantum Ctrl-Add circuit. Our proposed quantum non-
restoring divider saves T gates by not doing computation in
the QFT domain. We also base our design on the T gate
efficient quantum subtractor, quantum Add-Sub circuit and the
novel quantum Ctrl-Add circuit presented in Section II. The
modules used in our proposed quantum circuit do not produce
garbage outputs and restore inputs to their original values.
Thus, we are able to save qubits and T gates by placing these
quantum circuits such that our proposed quantum restoring
division circuit will produce no garbage outputs. We are able
to save additional qubits and T gates because the remainder
will be at most n − 1 bits wide when we divide two n bit
numbers with our proposed divider.
This proposed quantum integer division circuit calculates
division by implementing the non-restoring division algorithm.
The non-restoring division algorithm is illustrated in Figure
6. Existing research has demonstrated the correctness of the
non-restoring division algorithm through functionally correct
circuit implementations such as those in [23] [16].
Consider the division of two n bit 2’s complement positive
binary numbers a and b. Let |B〉 be a n bit quantum register
where that is initialized to the value b, let |R〉 be a n − 1
quantum register where each register location is initialized
with the value ai for 0 ≤ i ≤ n − 2 and let |Q〉 be a n
bit quantum register where register location |Q0〉 is initialized
with the value an−1 and the remaining n− 1 locations in |Q〉
Algorithm 2: Non-restoring division algorithm
Function Non-Restoring(a, b)
Requirements: a and b are positive and 2’s complement.
//Takes 2 n bit values a and b as input.
//Returns the quotient as an n bit number Q and
//the remainder from the division as an n− 1 bit
//number R.
1 R = 0n−1; // Where 0n−1 are n− 1 zeros.
2 Q = 0n−1an−1; // Where 0n−1 are n− 1 zeros.
3 // Q’s least significant bit has the value an−1
4 // an−1 is the most significant bit of a.
5 Q = Q− b
6
7 For i = 1 to n− 1
8 Qn−i = Qn−i
9 Y = Qn−1−i · · ·Q0Rn−2 · · ·Rn−1−i
10 // Where Qn−1−i is the most
11 // significant bit of Y .
12 If (Qn−i = 0)
13 Y = Y + b
14 Else
15 Y = Y − b
16 End
17 End
18
19 If (R < 0)
20 R = R+ b
21 End
22 Q0 = Q0
23 Return Q,R
Fig. 6: The non-restoring division algorithm.
are initialized to 0. At the end of computation, the quantum
register |B〉 will be restored to the value b while the quantum
register |R〉 will have the remainder of the division of a by
b. At the end of computation, the quantum register |Q〉 will
have the quotient of the division of a by b.
The proposed methodology is generic in nature and can
design a quantum non-restoring integer division circuit of any
size. The steps of the proposed methodology are presented
along with an illustrative example of the proposed quantum
non-restoring integer division circuit for the division of two
6 bit numbers a0 . . . a5 and b0 . . . b5 shown in Figure 7. The
proposed methodology has three steps. A quantum circuit is
generated for each step of the design.
A. Steps of the Proposed Design Methodology
• Step 1: This step executes line 5 of Algorithm 2 in
quantum hardware. Step 1 is shown for a 6 bit restoring
divider in Figure 7a. Apply the quantum registers |Q〉
and |B〉 to a quantum subtraction circuit such that, at
the end of computation, the quantum register |B〉 is
8|B5:0〉 • |B5:0〉
|R0〉 |R0〉
|R1〉 |R1〉
|R2〉 |R2〉
|R3〉 |R3〉
|R4〉 |R4〉
|Q0〉
S
u
b
tr
ac
ti
o
n
|Q0〉
|Q1〉 |Q1〉
|Q2〉 |Q2〉
|Q3〉 |Q3〉
|Q4〉 |Q4〉
|Q5〉 |Q5〉
(a) After Step 1
|B5:0〉 • • |B5:0〉
|R0〉 |R0〉
|R1〉 |R1〉
|R2〉 |R2〉
|R3〉 |R3〉
|R4〉
A
d
d
-S
u
b
|R4〉
|Q0〉
S
u
b
tr
ac
ti
o
n
|Q0〉
|Q1〉 |Q1〉
|Q2〉 |Q2〉
|Q3〉 |Q3〉
|Q4〉 |Q4〉
|Q5〉 • |Q5〉
(b) After iteration 1
of Step 2
|B5:0〉 • • • • • • |B5:0〉
|R0〉
A
d
d
-S
u
b
|R0〉
|R1〉
A
d
d
-S
u
b
|R1〉
|R2〉
A
d
d
-S
u
b
|R2〉
|R3〉
A
d
d
-S
u
b
|R3〉
|R4〉
A
d
d
-S
u
b
|R4〉
|Q0〉
S
u
b
tr
ac
ti
o
n
|Q0〉
|Q1〉 • |Q1〉
|Q2〉 • |Q2〉
|Q3〉 • |Q3〉
|Q4〉 • |Q4〉
|Q5〉 • |Q5〉
(c) After final iteration of Step 2
|B4:0〉 • • • • • • • |B4:0〉
|B5〉 • • • • • • |B5〉
|R0〉
A
d
d
-S
u
b
C
tr
l-
A
d
d
|R0〉
|R1〉
A
d
d
-S
u
b
|R1〉
|R2〉
A
d
d
-S
u
b
|R2〉
|R3〉
A
d
d
-S
u
b
|R3〉
|R4〉
A
d
d
-S
u
b
|R4〉
|Q0〉
S
u
b
tr
ac
ti
o
n
• |Q0〉
|Q1〉 • |Q1〉
|Q2〉 • |Q2〉
|Q3〉 • |Q3〉
|Q4〉 • |Q4〉
|Q5〉 • |Q5〉
(d) After Step 3
Fig. 7: Circuit generation of proposed quantum non-restoring
division circuit (illustrated with a 6 bit divider).
unchanged while quantum register |Q〉 now has the result
of computation.
• Step 2: this step is repeated n− 1 times and has the fol-
lowing four sub-steps. This step executes lines 8 through
16 of Algorithm 2 in quantum hardware. Iteration 1 of
Step 2 is shown for a 6 bit restoring divider in Figure 7b.
The final Iteration of Step 2 is shown for a 6 bit restoring
divider in Figure 7c. We show the steps for iteration i
where 1 ≤ i ≤ n− 1.
– Sub-step 1: This sub-step executes line 9 of Algo-
rithm 2 in quantum hardware. Treat the locations
|Rn−2〉 through |Rn−1−i〉 of quantum register |R〉
and locations |Qn−1−i〉 through |Q0〉 of register |Q〉
as a combined quantum register |Y 〉. The values
at locations |Rn−2〉 through |Rn−1−i〉 will occupy
locations |Yi−1〉 through |Y0〉 and the values at
locations |Qn−1−i〉 to |Q0〉 will occupy locations
|Yn−1〉 through |Yi〉.
– Sub-step 2: This sub-step executes line 8 of Algo-
rithm 2 in quantum hardware and prepares location
|Qn−i〉 for use in subsequent sub-steps.. At quantum
register location |Qn−i〉 apply a quantum NOT gate.
Location |Qn−i〉 now has the quotient bit qn−i of
the division of a by b.
– Sub-step 3: Apply the quantum registers |B〉 and
|Y 〉 to a quantum Add-Sub circuit such that |B〉
is unchanged while |Y 〉 will hold the result of
computation.
– Sub-step 4: Apply the quantum register location
|Qn−i〉 to the quantum Add-Sub circuit such that the
operation of the circuit is conditioned on the value
at location |Qn−i〉. Location |Qn−i〉 is unchanged.
If |Qn−i〉 = 0, this step executes line 13 of Algorithm 2.
If |Qn−i〉 = 1, this step executes line 15 of Algorithm 2.
• Step 3: This step executes lines 19 through 22 of Algo-
rithm 2 in quantum hardware. Step 3 is shown for a 6 bit
restoring divider in Figure 7d. This step has the following
three sub-steps:
– Sub-step 1: Apply locations |Bn−2〉 through |B0〉 of
quantum register |B〉 and quantum register |R〉 to a
quantum Ctrl-Add circuit such that locations |Bn−2〉
through |B0〉 are unchanged while quantum register
|R〉 is transformed to the remainder.
– Sub-step 2: Apply location |Q0〉 of register |Q〉 to the
quantum Ctrl-Add circuit such that the operation of
the circuit is conditioned on the value at register loca-
tion |Q0〉. Location |Q0〉 is unchanged. If |Q0〉 = 1,
Step 1 and Step 2 execute line 21. After this Sub-step
2, quantum register |R〉 will contain the remainder
of the division of a by b.
– Sub-step 3: At quantum register location |Q0〉, apply
a quantum NOT gate. Step 3 executes line 23 of
Algorithm 2. Location |Q0〉 now has the quotient bit
q0 of the division of a by b. After this step, quantum
register |Q〉 will contain the quotient of the division
of a by b.
VI. COST ANALYSIS OF THE PROPOSED NON-RESTORING
DIVISION CIRCUIT
A. T-Count Analysis
The T-count of the proposed quantum integer division
circuit is illustrated shortly for each step of the proposed
design methodology:
• The T-count for Step 1 is 14 · n− 14. We use a quantum
subtraction circuit of T-count 14 · n− 14 in this step.
• Step 2 is repeated n − 1 times. The T-count for each
iteration of Step 2 is 14 · n − 14. We use a quantum
Add-Sub circuit of T-count 14 · n− 14 in this step.
• The T-count for Step 3 is 21 · n− 21. We use a quantum
Ctrl-Add circuit of size n − 1 in this step. We use a
quantum Ctrl-Add circuit of T-count 21 · n − 14 in this
step.
9TABLE IV: Comparison of Quantum Integer Division Circuits
1 2 3 Proposed
T count 28 · n2 42 · n2 + 28 · n ≈ 9 · n3 14 · n2 + 7 · n+ 7
T-depth NA NA NA 10 · n+ 13
qubits 2 · n2 + 5 · n− 1 3 · n2 + 14 · n ≈ 1
2
n
3 + 4 · n 3 · n− 1
1 and 2 are the designs by Jamal et al. [23] modified to remove garbage output.
3 is the design by Dibbo et al. [13] modified to remove garbage output.
Table entries are marked NA where a closed-form expression is not available for
the designs by Jamal et al. and Dibbo et al.
TABLE V: T-count Comparison of Quantum Integer Division Circuits
n 1 2 3 Proposed % Impr. % Impr. % Impr.
w.r.t. 1 w.r.t. 2 w.r.t. 3
4 448 784 ≈ 576 217 51.56 72.32 ≈ 62.33
8 1792 2912 ≈ 4608 917 48.83 68.51 ≈ 80.10
16 7168 11200 ≈ 36864 3661 48.93 67.31 ≈ 90.07
32 28672 43904 ≈ 294912 14525 49.34 66.92 ≈ 95.07
64 114688 173824 ≈ 2359296 57757 49.64 66.77 ≈ 97.55
128 458752 691712 ≈ 18874368 230237 49.81 66.71 ≈ 98.78
256 1835008 2759680 ≈ 150994944 919261 49.90 66.69 ≈ 99.39
512 7340032 11024384 ≈ 1207959552 3673565 49.95 66.68 ≈ 99.70
Average: 49.75 67.74 90.37
1 and 2 are the designs by Jamal et al. [23] modified to remove garbage output.
3 is the design by Dibbo et al. [13] modified to remove garbage output.
TABLE VI: Qubit Cost Comparison of Quantum Integer Division Circuits
n 1 2 3 Proposed % Impr. % Impr. % Impr.
w.r.t. 1 w.r.t. 2 w.r.t. 3
4 51 104 ≈ 48 11 78.43 89.42 ≈ 77.08
8 167 304 ≈ 288 23 86.23 92.43 ≈ 92.01
16 591 992 ≈ 2112 47 92.05 95.26 ≈ 97.77
32 2207 3520 ≈ 16512 95 95.70 97.30 ≈ 99.42
64 8511 13184 ≈ 131328 191 97.76 98.55 ≈ 99.85
128 33407 50944 ≈ 1049088 383 98.85 99.25 ≈ 99.96
256 132351 200192 ≈ 8389632 767 99.42 99.62 ≈ 99.99
512 526847 793600 ≈ 67110912 1535 99.71 99.81 ≈ 99.99
Average: 93.52 96.46 95.76
1 and 2 are the two designs from Jamal et al. [23] modified to remove garbage output.
3 is the design by Dibbo et al. [13] modified to remove garbage output.
We determine the total T-count by summing the T-count for
each step in the design as shown below:
14 · n− 14 + (14 · n− 14) · (n− 1) + 21 · n− 21 (4)
This expression can be simplified to the following:
14 · n2 + 7 · n− 35 (5)
B. T-depth Cost
The T-depth of the proposed quantum integer division
circuit is illustrated shortly for each step of the design method-
ology. Our proposed design is based on T-depth efficient
designs of quantum subtractors, quantum Add-Sub circuits and
quantum Ctrl-Add circuits. We determined that garbageless
and T gate optimized quantum subtractor and quantum Add-
Sub circuits in the literature such as the designs in [19] have
a T-depth that is constant and independent of the circuit size
n. Thus, these quantum circuits have T-depth of order O(1).
We determined as well that Ctrl-Add circuits in the literature
such as the design in [21] scale as a function of circuit size n.
Thus, these Ctrl-Add circuits have a T-depth of order O(n).
• Step 1 has a constant T-depth of 10. This T-depth is seen
by locations |B1〉 through |Bn−2〉 of quantum register
|B〉. We use a quantum subtraction circuit of constant
T-depth 10 in this step (where T-depth is independent of
circuit size n).
• Step 2 is repeated n− 1 times. The ith iteration of Step
2 (where 1 ≤ i ≤ n − 1) has a constant T-depth of 10.
This T-depth is seen by locations |B1〉 through |Bn−2〉 of
quantum register |B〉. We use a quantum Add-Sub circuit
of constant T-depth 10 in this step (where T-depth is
independent of circuit size n).
• Step 3 has a T-depth of 2 · n. This T-depth is seen by
location |Q0〉 of quantum register |Q〉. We use a quantum
Ctrl-Add circuit of T-depth 2 · n in this Step.
We now illustrate the steps to determine the total T-depth
for the proposed quantum integer division circuit:
1) Calculate the T-depth for Step 1. Step 1 has a T-depth
of 10. This T-depth is seen by locations |B1〉 through
10
|Bn−2〉 of quantum register |B〉.
2) Calculate the T-depth for all iterations of Step 2. The
total T-depth for all iteration of Step 2 has a T-depth of
10 · (n− 1) because each iteration of Step 2 requires a
quantum Add-Sub circuit. The total T-depth 10 · (n− 1)
simplifies to 10·n−10. This T-depth is seen by locations
|B1〉 through |Bn−2〉 of quantum register |B〉.
3) Calculate the T-depth for Step 3. Step 3 has a T-depth of
2 · n. This T-depth is seen by location |Q0〉 of quantum
register |Q〉.
4) Determine which qubits see the most T gate layers. We
find after comparing all the qubits in our proposed de-
sign, quantum register location |Q0〉 of quantum register
|Q〉 and quantum register locations |B1〉 through |Bn−2〉
of quantum register |B〉 see the most T gate layers.
5) Determine the total number of T gate layers seen by
quantum register location |Q0〉 in the proposed design.
Quantum register |Q0〉 will see a total of 6 · n − 4 T
gate layers because in Step 1 location |Q0〉 sees 4 T
gate layers, in Step 2 location |Q0〉 sees 4 · (n − 2) T
gate layers and in Step 2 location |Q0〉 sees 2 · n T
gate layers. The total number of T gate layers seen by
location |Q0〉 is 4 + 4 · (n− 2) + 2 · n which simplifies
to 6 · n− 4.
6) Determine the total number of T gate layers seen by
quantum register locations |B1〉 through |Bn−2〉 in
the proposed design. Quantum register locations |B1〉
through |Bn−2〉 will see a total of 10·n+13 T gate layers
because in Step 1 locations |B1〉 through |Bn−2〉 see 10
T gate layers, in Step 2 locations |B1〉 through |Bn−2〉
sees 10 · (n − 1) T gate layers and in Step 3 locations
|B1〉 through |Bn−2〉 see 13 T gate layers. The total
number of T gate layers seen by locations |B1〉 through
|Bn−2〉 is 10 + 10 · (n − 1) + 13 which simplifies to
10 · n+ 13.
7) Determine which qubits see the most T gate layers. We
determined that locations |B1〉 through |Bn−2〉 see more
T gate layers than register location |Q0〉 because 10 ·n+
13 > 6 · n− 4.
Thus, our proposed design has a T-depth of 10 · n + 13
and this T-depth is seen by locations |B1〉 through |Bn−2〉 of
quantum register |B〉.
C. Cost Comparison
Comparison of the proposed design with the current state
of the art are presented in Tables IV, V and VI. We compare
our proposed design to the existing quantum non-restoring
division circuits by Jamal et al. [23] and the alternative design
methodology presented in Dibbo et. al. [13]. To perform the
comparison we implemented each design with Clifford+T
gates. To realize reversible gates such as the Toffoli gate,
we use the Clifford+T implementations presented in [8]. As
ahown in [8], the Toffoli gate has a T-count of 7 and a T-
depth of 3. We also apply the Bennett’s garbage removal
scheme illustrated in [22] to remove the garbage outputs from
each design presented by Jamal et al. and Dibbo et. al. We
determined the qubit cost for each design in Jamal et. al.
by summing the qubits required for the quotient, remainder,
garbage outputs, and primary inputs. We estimated the qubit
cost for each design by summing the qubits required for the
quotient, remainder, garbage outputs, and primary inputs.
1) Cost Comparison in Terms of T-count: Table IV illus-
trates that the T-count cost of the proposed design and the
designs by Jamal et al. are O(n2). The design by Dibbo
et. al. has a T-count cost of order O(n3). Table V shows
that our proposed design methodology achieves improvement
ratios ranging from 49.95% to 51.56%, 66.68% to 72.32%
and 62.33% to 99.70% compared to the designs by Jamal et
al. and the design by Dibbo et. al. in terms of T-count.
2) Cost Comparison in Terms of Qubits: Table IV shows
that our proposed design has a qubit cost of order O(n) while
the qubit cost for the designs by Jamal et al. are of order
O(n2). Table IV also illustrates that the design by Dibbo
et. al. has a qubit cost of order O(n3). Table VI shows
the comparison of our proposed design methodology to the
designs presented by Jamal et al. and Dibbo et. al. for values of
n ranging from 4 to 512 in terms of qubit cost. We calculated
that our proposed design methodology achieves improvement
ratios ranging from 78.43% to 99.71%, 89.42% to 99.81%
and 77.08% to 99.99% compared to the designs by Jamal et
al. and the design by Dibbo et. al.
3) Cost Comparison in Terms of T-depth: The T-depth cost
of the proposed design is O(n). A closed-form expression is
not available for the designs by Jamal et al. and the design by
Dibbo et al. for the T-depth.
VII. CONCLUSION
In this work, we have proposed two designs for quantum
circuit integer division based on Clifford+T gates. The first
quantum integer division circuit proposed is based on the
restoring division algorithm and the second is based on the
non-restoring division algorithm. We also show the design of
components used in our proposed quantum integer division
circuits such as the quantum subtraction circuit, quantum
Add-Sub circuit and quantum Ctrl-Add circuit. The proposed
quantum restoring division circuit is shown to be superior
to existing designs in terms of T-depth, T-count and qubits.
Likewise, the proposed quantum non-restoring division circuit
is shown to be superior to existing designs in terms of T-
count and qubits. We conclude that the proposed restoring
division circuit or proposed non-restoring division circuit can
be integrated in a larger quantum data path system design
where T-count and T-depth are of primary concern.
REFERENCES
[1] P. Selinger et al., The Quipper System, 2016, available at:
http://www.mathstat.dal.ca/ selinger/quipper/doc/.
[2] S. Hallgren, “Polynomial-time quantum algorithms for pell’s
equation and the principal ideal problem,” J. ACM, vol. 54,
no. 1, pp. 4:1–4:19, Mar. 2007. [Online]. Available:
http://doi.acm.org/10.1145/1206035.1206039
[3] W. van Dam and S. Hallgren, “Efficient Quantum Algorithms for
Shifted Quadratic Character Problems,” eprint arXiv, Nov. 2000.
[Online]. Available: https://arxiv.org/abs/quant-ph/0011067
[4] W. van Dam, S. Hallgren, and L. Ip, “Quantum algorithms
for some hidden shift problems,” SIAM Journal on Computing,
vol. 36, no. 3, pp. 763–778, 2006. [Online]. Available:
https://doi.org/10.1137/S009753970343141X
11
[5] D. Wecker et al., Language-Integrated Quantum Operations:
LIQUi|〉, 2016, available at: https://www.microsoft.com/en-
us/research/project/language-integrated-quantum-operations-liqui/.
[6] E. Fredkin and T. Toffoli, “Conservative logic,” International Journal
of Theoretical Physics, vol. 21, no. 3, pp. 219–253, 1982. [Online].
Available: http://dx.doi.org/10.1007/BF01857727
[7] X. Zhou, D. W. Leung, and I. L. Chuang, “Methodology for quantum
logic gate construction,” Phys. Rev. A, vol. 62, p. 052316, Oct 2000. [On-
line]. Available: https://link.aps.org/doi/10.1103/PhysRevA.62.052316
[8] M. Amy, D. Maslov, M. Mosca, and M. Roetteler, “A meet-in-the-
middle algorithm for fast synthesis of depth-optimal quantum circuits,”
IEEE Transactions on Computer-Aided Design of Integrated Circuits
and Systems, vol. 32, no. 6, pp. 818–830, June 2013.
[9] A. Paler, I. Polian, K. Nemoto, and S. J. Devitt, “Fault-tolerant, high-
level quantum circuits: form, compilation and description,” Quantum
Science and Technology, vol. 2, no. 2, p. 025003, 2017. [Online].
Available: http://stacks.iop.org/2058-9565/2/i=2/a=025003
[10] D. Gosset, V. Kliuchnikov, M. Mosca, and V. Russo, “An
algorithm for the t-count,” Quantum Information & Computation,
vol. 14, no. 15-16, pp. 1261–1276, 2014. [Online]. Available:
http://www.rintonpress.com/xxqic14/qic-14-1516/1261-1276.pdf
[11] A. Khosropour, H. Aghababa, and B. Forouzandeh, “Quantum division
circuit based on restoring division algorithm,” in Information Technol-
ogy: New Generations (ITNG), 2011 Eighth International Conference
on. IEEE, 2011, pp. 1037–1040.
[12] L. Jamal and H. M. H. Babu, “Efficient approaches to design a reversible
floating point divider,” in 2013 IEEE International Symposium on
Circuits and Systems (ISCAS2013), May 2013, pp. 3004–3007.
[13] S. V. Dibbo, H. M. H. Babu, and L. Jamal, “An efficient design technique
of a quantum divider circuit,” in 2016 IEEE International Symposium
on Circuits and Systems (ISCAS), May 2016, pp. 2102–2105.
[14] V. Kliuchnikov, D. Maslov, and M. Mosca, “Fast and efficient exact
synthesis of single-qubit unitaries generated by clifford and t gates,”
Quantum Info. Comput., vol. 13, no. 7-8, pp. 607–630, Jul. 2013.
[Online]. Available: http://dl.acm.org/citation.cfm?id=2535649.2535653
[15] H. Thapliyal, T. S. S. Varun, and E. Mun˜oz-Coreas, “Quantum circuit
design of integer division optimizing ancillary qubits and t-count,” in
16th Asian Quantum Information Science Conference, August 2016, pp.
197–199.
[16] H. Thapliyal, T. S. S. Varun, E. Mun˜oz-Coreas, K. A. Britt, and T. S.
Humble, “Quantum circuit designs of integer division optimizing t-count
and t-depth,” in 2017 IEEE International Symposium on Nanoelectronic
and Information Systems (iNIS), Dec 2017, pp. 123–128.
[17] IBM, Quantum Computing - IBM Q, 2017, available at:
https://www.research.ibm.com/ibm-q/.
[18] C. Song, K. Xu, W. Liu, C.-p. Yang, S.-B. Zheng, H. Deng, Q. Xie,
K. Huang, Q. Guo, L. Zhang, P. Zhang, D. Xu, D. Zheng, X. Zhu,
H. Wang, Y.-A. Chen, C.-Y. Lu, S. Han, and J.-W. Pan, “10-Qubit
Entanglement and Parallel Logic Operations with a Superconducting
Circuit,” Physical Review Letters, vol. 119, no. 18, p. 180511, Nov.
2017.
[19] H. Thapliyal, “Mapping of subtractor and adder-subtractor circuits on
reversible quantum gates,” in Transactions on Computational Science
XXVII. Springer, 2016, pp. 10–34.
[20] H. Thapliyal and N. Ranganathan, “Design of efficient reversible logic-
based binary and bcd adder circuits,” ACM Journal on Emerging
Technologies in Computing Systems (JETC), vol. 9, no. 3, p. 17, 2013.
[21] E. Mun˜oz-Coreas and H. Thapliyal, “T-count Optimized Design of
Quantum Integer Multiplication,” ArXiv e-prints, Jun. 2017. [Online].
Available: https://arxiv.org/abs/1706.05113
[22] C. H. Bennett, “Logical reversibility of computation,” IBM J. Res.
Dev., vol. 17, no. 6, pp. 525–532, Nov. 1973. [Online]. Available:
http://dx.doi.org/10.1147/rd.176.0525
[23] L. Jamal and H. M. H. Babu, “Efficient approaches to design a reversible
floating point divider,” in 2013 IEEE International Symposium on
Circuits and Systems (ISCAS2013), May 2013, pp. 3004–3007.
