Fault-tolerant Quantum Error Correction on Near-term Quantum Processors
  using Flag and Bridge Qubits by Lao, Lingling & Almudever, Carmen G.
Fault-tolerant Quantum Error Correction on Near-term Quantum Processors using
Flag and Bridge Qubits
Lingling Lao, Carmen G. Almudever
QuTech, Delft University of Technology, The Netherlands
Fault-tolerant (FT) computation by using quantum error correction (QEC) is essential for realizing
large-scale quantum algorithms. Devices are expected to have enough qubits to demonstrate aspects
of fault tolerance in the near future. However, these near-term quantum processors will only contain
a small amount of noisy qubits and allow limited qubit connectivity. Fault-tolerant schemes that not
only have low qubit overhead but also comply with geometrical interaction constraints are therefore
necessary. In this work, we combine flag fault tolerance with quantum circuit mapping, to enable
an efficient flag-bridge approach to implement FT QEC on near-term devices. We further show an
example of performing the Steane code error correction on two current superconducting processors
and numerically analyze their performance with circuit level noise. The simulation results show
that the QEC circuits that measure more stabilisers in parallel have lower logical error rates. We
also observe that the Steane code can outperform the distance-3 surface code using flag-bridge error
correction. In addition, we foresee potential applications of the flag-bridge approach such as FT
computation using lattice surgery and code deformation techniques.
I. INTRODUCTION
Near-term quantum processors will consist of fifty to
a few hundred noisy qubits and allow a limited num-
ber of faulty gates. They are also known as Noisy-
Intermediate-Scale Quantum (NISQ) [1] processors. For
instance, Google, IBM, and Intel have respectively an-
nounced 72-qubit [2], 50-qubit [3], and 49-qubit [4] su-
perconducting processors which have coherence times of
∼ 100 microseconds and two-qubit gate error rates near
0.1% [5]. Many efforts have been focusing on designing
special quantum applications [6, 7] and developing com-
pilation techniques [8, 9] such that one can solve practical
problems and even demonstrate quantum supremacy on
NISQ processors only using noisy bare qubits.
However, fault tolerance will be necessary to reliably
implement large-scale quantum algorithms. This can be
achieved through the use of active quantum error cor-
rection (QEC). The idea of QEC is to encode one logi-
cal qubit into many physical qubits and repeatedly per-
form syndrome extraction to detect and correct errors.
Both the encoding and error detection procedure should
be fault-tolerant (FT). Furthermore, operations on these
logical qubits need to be performed fault-tolerantly. Al-
though the high qubit overhead of QEC makes it difficult
to realize scalable FT computation in the near future, we
can begin to show how fault tolerance works in practice.
The first step is to demonstrate fault-tolerant quantum
error correction, that is, FT quantum memory.
General fault-tolerant quantum error correction pro-
tocols such as those from Shor [10], Steane [11], and
Knill [12] can be applied to various stabiliser codes. How-
ever, these error correction schemes all require many an-
cilla qubits, which are scarce resources in near-term quan-
tum processors. In order to perform FT QEC with low
qubit overhead, a new error correction protocol has been
proposed [13–16]. It replaces a non-FT syndrome extrac-
tion circuit by a circuit which can detect correlated (or
hook) errors by adding only one or a few extra ancilla
qubits, called flag qubits.
This flag QEC scheme provides an efficient way to
demonstrate fault tolerance in small experiments. How-
ever, many orthodox flag circuits couple one qubit to
many others, requiring high-degree qubit connectivity.
It is difficult or even impossible to directly map avail-
able flag circuits onto near-term quantum processors
which have geometrical interaction constraints such as
the nearest-neighbour connectivity in superconducting
processors [17–19]. One may need to apply extra opera-
tions such as SWAP gates to move qubits to be adjacent,
increasing the circuit size in terms of depth and total
gate number, or even circuit width. More importantly,
the resulting circuit may not be fault-tolerant, or produce
higher error rates when used.
In this work, we extend the set of available flag cir-
cuits to a variety of equivalent circuits that can per-
form the same stabiliser measurement fault-tolerantly. In
these circuits, the flag qubits are also used as bridges
to cope with the connectivity constraints, called flag-
bridge qubits. Using these circuits, one can fault-
tolerantly map a QEC code to a given processor with
low overhead by choosing appropriate flag-bridge circuits.
We also develop a simulation framework to automate the
procedure of fault tolerance checking, decoder design (in-
cluding a look-up-table decoder and a neural-network de-
coder) for given flag-bridge circuits of some low-distance
QEC codes. This automation is desirable for demon-
strating fault-tolerant quantum error correction in small
experiments. Moreover, we present mapping examples of
the Steane code on two different qubit processor topolo-
gies and analyze their fault tolerance numerically. In
addition, we show the proposed flag-bridge approach can
be applied to FT computation implemented by lattice
surgery and code deformation techniques.
The rest of this paper is organized as follows. We first
review the basics of flag-based quantum error correction
in Section II. Then we introduce the proposed flag-bridge
ar
X
iv
:1
90
9.
07
62
8v
1 
 [q
ua
nt-
ph
]  
17
 Se
p 2
01
9
2approach in Section III. Afterwards, the mapping of the
Steane code onto two qubit processor topologies and cor-
responding numerical results are shown in Section IV.
Moreover, we provide the potential applications of flag-
bridge circuits in Section V. Finally, Section VI concludes
the paper.
II. FLAG-BASED QUANTUM ERROR
CORRECTION
In this section, we briefly introduce the flag-based er-
ror syndrome extraction for stabiliser codes. For more
details, we refer the readers to [13–16, 20].
Figure 1 shows the circuits for measuring a weight-4
Z-stabiliser (or check), similar circuits can be derived for
measuring other Pauli operators. In all the circuits pre-
sented in this paper, a cnot gate between a data qubit
and an ancilla qubit is called an s-cnot (in black) and a
cnot gate between two ancilla qubits is called an f-cnot
(in blue). Generally, the syndrome for this Z-check can
be extracted using the circuit with only one ancilla qubit
(Figure 1a). However, this circuit is not fault-tolerant be-
cause one single fault could cause 2 or more data errors.
These correlated errors may lead to failures of some QEC
codes. The surface code is an exception which can correct
these hook errors if the two-qubit gates are performed in
a specific order [21]. In order to perform fault-tolerant
quantum error correction, one can use the flag circuits in
Figures 1b and 1c that only add one extra ancilla qubit.
When there is no fault, each of these flag circuits behaves
the same as the non-FT one. When there is a fault that
can lead to hook errors, the measurement of the flag qubit
will be nontrivial such that the hook errors are detected.
For instance, if the same fault in Figure 1a happens in
the circuit of Figure 1b, then the measurement of qubit
f will be ‘1’ (raising a flag).
Flag-based quantum error correction can be applied
to many codes such as the J5, 1, 3K code, Hamming
codes, surface codes, color codes, etc. For example, fault-
tolerant QEC for the smallest color code, the Steane code
in Figure 2, can be realized as follows: first measure each
stabiliser generator one by one using flag circuits simi-
lar to those in Figure 1; if a flag raises or a syndrome
appears, then stop this round1 and sequentially measure
all the stabilisers using the non-FT syndrome extraction
circuit. Note that if connectivity is fixed, we can’t neces-
sarily change the syndrome measurement circuit all of a
sudden. One can use only two ancilla qubits to perform
FT QEC for the Steane code at the cost of using more
time steps. However, many quantum systems have very
short coherence times [17, 22, 23]. Parallelizing stabiliser
measurement will be beneficial to achieve lower logical
1 A full round of error syndrome extraction is defined as measuring
all the stabiliser generators of the code for one time.
a
b
c
d
s |0〉
Z
Z
Z
Z
(a)
a
b
c
d
s |0〉
f |+〉 X
Z
(b)
a
b
c
d
s |0〉
f |+〉
Z
X
(c)
FIG. 1: The syndrome extraction circuits for the Za,b,c,d
operator, where s is the syndrome qubit and f is the
flag qubit. (a) The circuit only using one syndrome
ancilla may not be fault-tolerant. For example, one
fault (Zs) on the second cnot gate could lead to
correlated weight-2 errors on data qubits (Za, Zb),
which may not be correctable. (b) and (c) The
flag-based circuits can detect these hook errors [13–15].
1
4
3
7
2 5 6
FIG. 2: (Left) The qubit layout of the J7, 1, 3K Steane
code. Data qubits are on the vertices and each plaquette
represents two stabilisers: one weight-4 X-stabiliser and
one weight-4 Z-stabiliser. (Right) all the six stabiliser
generators and logical X and Z operators.
error rates. Chao and Reichardt [14, 16] have proposed
several circuits to perform two or three parity checks in
parallel for the Steane code. The circuits they propose for
measuring two and three Z-checks at the same time us-
ing only one flag qubit are shown in Figure 3. As shown,
more ancilla qubits are required to achieve this paral-
lelism compared to the sequential stabiliser measurement
circuits. This implies there is a trade-off between the
number of qubits required and the number of stabilisers
that can be measured simultaneously.
Flag-based syndrome extraction is promising for
demonstrating quantum error correction and fault tol-
erance in small quantum experiments because of its low
qubit overhead. However, current or near-term quantum
processors have many hardware limitations. One of the
main constraints is the degree of qubit connectivity, that
is, one qubit can only interact with a limited number of
other qubits. It is challenging to map existing flag cir-
cuits onto connectivity-constrained quantum processors
3s1 |0〉
s2 |0〉
f |+〉
Z
Z
X
(a)
s1 |0〉
s2 |0〉
s3 |0〉
f |+〉
Z
Z
Z
X
(b)
FIG. 3: Flag circuits [14, 16] for (a) measuring two
weight-4 Z-checks in parallel using three ancillas and
(b) measuring three weight-4 Z-checks in parallel using
four ancillas.
meanwhile maintaining the fault tolerance with low costs.
For instance, the ancilla qubit s of the flag circuit in Fig-
ure 1b needs to interact with five qubits, which cannot
be supported in a grid topology where each qubit only
has at most four neighbours such as the one in [18].
Besides, general circuit mapping techniques [24–28] that
move qubits to be adjacent by applying SWAP gates will
lead to high overhead in the circuit size. More impor-
tantly, it may result in higher logical error rates or even
destroy the fault tolerance of the QEC circuits because
of the error propagation through two-qubit gates. In this
work, we propose a flag-bridge approach to solve this
mapping problem, which will be explained in the next
section.
III. FLAG-BRIDGE QUANTUM ERROR
CORRECTION
In this section, we illustrate the proposed flag-bridge
approach which allows fault-tolerant quantum error cor-
rection with low qubit overhead on connectivity-limited
quantum processors.
A. Flag-bridge syndrome extraction circuits
We first provide a microscopic explanation of how a
flag-based circuit can perform a specific stabiliser mea-
surement using the stabiliser formalism [29]. Then we
generalise this flag scheme such that one can extend avail-
able flag circuits to more equivalent ones that are differ-
ent in terms of the total number of gates, circuit depth,
and connectivity requirement. We will use the circuit
in Figure 1c as an example. A flag syndrome extrac-
tion circuit can be understood as a circuit that replaces
the bare ancilla qubit by an ‘encoded’ ancilla up to gate
commutation. As shown in Figure 1c, the first blue cnot
gate entangles ancilla qubit s and qubit f (the encoding
circuit), encoding a logical ancilla in a J2, 1, 1K error de-
tection code of which stabiliser is
〈Xs ⊗Xf 〉
and logical operators are〈
X = Xs, Z = Zs ⊗ Zf
〉
.
This logical qubit is fixed in the Z basis. Then one can
perform stabiliser measurement using this logical ancilla.
Assume the four data qubits (a, b, c, d) are initially stabi-
lized by (−1)yZa,b,c,d, the four subsequent s-cnot gates
between data qubits and ancilla qubits will keep the sta-
bilisers of all the qubits invariant, which are,
〈Xs ⊗Xf , (−1)yZ4,5,6,7〉 ,
but it will gradually transform the logical operators into〈
X = Xs, Z = Zs ⊗ Zf ⊗ (−1)yZ4,5,6,7
〉
.
More generally, since Xf and Xs have the same effect
on the encoded ancilla state, one can perform each s-
cnot gate between the particular data qubit with any
ancilla qubit. Specifically, in the encoded ancilla area, ks
and kf s-cnot gates can be applied on ancillas s and f
respectively, where ks and kf are integers and ks+kf = 4.
For example, the circuit shown in Figure 4a also performs
a weight-4 Z−stabiliser measurement equivalent to this
circuit (Figure 1c), where ks = 3 and kf = 1.
Afterwards, the last f-cnot (the decoding circuit) dis-
entangles these two ancillas, leading to the final stabiliser
to be
〈(−1)yZ4,5,6,7〉
and the logical operators of these ancillas to be
〈Xf , (−1)yZs〉 .
This means the readout y of measurement Mz on an-
cilla s indicates the measurement result of the stabiliser
Za,b,c,d. Therefore, this circuit indeed measures a weight-
4 Z-check. Besides, the measurement result of ancilla f
implies the syndrome of the J2, 1, 1K code, that is, it can
4detect one single Z error that occurs on any ancilla and
then raises a flag.
Once a flag circuit based on the above approach is gen-
erated, one can transform it into other equivalent ones
that can perform the same stabiliser measurement by ap-
plying gate commutation, e.g., the circuit in Figure 1b.
Note that the circuits generated by commuting gates may
not be fault-tolerant.
Moreover, one can use a larger ‘encoded’ ancilla to
measure a weight-n Z-check (similar circuits can be ap-
plied to other Pauli operators). This logical ancilla is
encoded by m physical qubits denoted by a set Q =
{1, 2, · · · ,m}, where one is syndrome qubit (Qs = {1})
and the other m − 1 are flag qubits (Qf = {2, · · · ,m}).
The underlying error detection code Jm, 1, 1K of this log-
ical ancilla has stabilisers
〈Xj ⊗Xk〉 , j ∈ Qs, k ∈ Qf
and logical operators〈
X = Xj , Z =
⊗
i
Zi
〉
, i, j ∈ Q.
Similar to the two-ancilla flag circuits, this weight-n
check can be distributed to all m ancillas, ki s-cnot gates
will be applied on ancilla i, where
∑m
i=1 ki = n. For ex-
ample, the circuit in Figure 4b measures one weight-4
Z-stabiliser using one syndrome qubit (s) and two flag
qubits (f1, f2), each qubit only needs to interact with at
most three others.
In addition, one can also measure p Z-checks in parallel
by encoding p logical ancillas into m physical ancillas.
The underlying Jm, p, 1K code is stabilized by〈
Xi ⊗
⊗
j
Xj
〉
, i ∈ Qf , j ∈ Qs.
Its p logical operators are〈
Xk = Xi, Zk = Zi ⊗ Zj
〉
, i, j ∈ Q, i < j.
Where, Qs is the set of p syndrome qubits and Qf is
the set of m − p flag qubits. After the encoding of an-
cilla qubits, one can simply assign all the s-cnot gates
for performing one check to a particular syndrome qubit.
Furthermore, one can reduce the total number of s-cnot
gates by applying gate commutation when two or more
checks are performed on the same data qubit(s). Fig-
ure 3a and Figure 3b show the flag circuits to measure
two and three checks of the Steane code in parallel by us-
ing ancillas encoded in a J3, 2, 1K code and in a J4, 3, 1K
code, respectively, These circuits use less s-cnot gates
than required by commuting some cnot gates out of the
encoded area (generally 4 s-cnot gates are needed for
each weight-4 check).
Moreover, one can achieve this gate reduction by dis-
tributing some s-cnot gates to flag qubits, which can
even help to reduce the circuit depth. Figure 5a shows
the example circuit that measures two checks of the
Steane code in parallel but uses less timesteps than Fig-
ure 3a. Note that the s-cnot distribution for parallel
syndrome measurement needs to be designed carefully
since one flag qubit is used for flagging multiple checks.
This distribution also depends on the decoding procedure
of the Jm, p, 1K code. Figure 5b shows the example cir-
cuit that measures three checks using less timesteps than
Figure 3b. Besides, the circuits in Figure 5 require less
degree of qubit connectivity than the ones in Figure 3.
By employing the ideas of encoding ancillas, distribut-
ing s-cnot , and commuting gates, we can generate
more equivalent syndrome extraction circuits that have
different connectivity requirements. Note that not all
the equivalent circuits generated using this approach are
fault-tolerant. The fault tolerance can be checked based
on the error correction protocol, which will be explained
in the next section. For these FT circuits, ancillas are not
only used as syndrome and flag qubits to detect errors,
but also as bridges to allow the interaction between data
qubits and the encoded ancilla block. Such a syndrome
extraction circuit is called a flag-bridge circuit.
s |0〉
f |+〉
Z
X
(a)
s |0〉
f1 |+〉
f2 |+〉 X
Z
X
(b)
FIG. 4: Flag-bridge circuits for measuring one weight-4
Z-check using (a) two ancillas and (b) three ancillas.
B. Fault-tolerant protocol for flag-bridge error
correction
1. FT QEC condition
For distance-3 codes, a QEC circuit is fault-tolerant if
it can either immediately correct all errors from a sin-
gle fault or only leave a weight-1 error to the next cy-
cle. A formal condition of FT flag-bridge quantum error
correction for distance-3 codes, similar to the flag error
correction in [15], can be defined as follows:
5s1 |0〉
s2 |0〉
f |+〉
Z
Z
X
(a)
s1 |0〉
s2 |0〉
s3 |0〉
f |+〉
Z
Z
Z
X
(b)
FIG. 5: Flag-bridge circuits which measure (a) two and
(b) three weight-4 Z-checks in parallel.
Consider a stabiliser code S = 〈g1, g2, · · · , gr〉 and
its QEC circuit C which is composed of the flag-bridge
circuits for measuring the stabiliser generators, that is,
C = {c(g1), c(g2), · · · , c(gr)}, where c(gi) is the flag cir-
cuit of measuring stabiliser gi. Note that the total
number of flag-bridge circuits is smaller than r if sev-
eral stabilisers are measured simultaneously in one flag-
bridge circuit. For all generators g, all pairs of elements
E,E′ ∈ E(g) satisfy sf(E) 6= sf(E′) or E ∼ E′, where
E(g) is the set of all errors caused by one fault, sf(E)
is the syndrome and flag string caused by E. We define
E ∼ E′ to mean that there is an element g in S such that
E′ ∝ gE, that is, these errors are stabiliser-equivalent.
Based on this criterion, we check the fault tolerance
of each generated QEC circuit C through a brute-force
simulation under circuit level noise, analogous to [13]. It
is implemented by injecting each individual fault from a
circuit-based error model on every single-qubit or two-
qubit gate in a given QEC circuit and then collecting the
final syndromes and flags. If there are two or more sets
of errors which lead to the same syndrome-flag string but
do not yield a stabiliser when multiplied, then this QEC
circuit is not fault-tolerant.
2. FT QEC procedure
A full cycle of fault-tolerant error correction for
distance-3 codes using flag-bridge circuits can be per-
formed as follows:
1. For the first round of syndrome extraction, each
circuit c(gi) ∈ C is sequentially performed. If there
are non-trivial flags f1i or non-trivial syndromes s
1
i
of c(gi), then this round will be terminated and
another full round for all circuits in C will be per-
formed. All the syndromes s2 =
⋃
i s
2
i and flags
f2 =
⋃
i f
2
i of the second round will be collected.
2. If f1i is not empty, one can decode using f
1
i and
s2 (and f2). If f1i is empty, but s
1
i is not empty,
one can decode using s2 (and f2). Otherwise, no
corrections are needed.
In this FT QEC procedure, we use flag-bridge circuits
for both rounds of syndrome extraction because of the
connectivity constraint, which is different from the ones
proposed in [14–16], where non-FT syndrome extraction
circuits that use only one ancilla are executed for the
second round.
3. Error decoders
Normally, error correction of topological codes like sur-
face codes have special structures for the measured syn-
dromes so that one can use heuristic algorithms to find
high-probability errors. These types of decoders such as
the minimum weight perfect matching decoder [30] and
the belief propagation decoder [31] can be applied to the
same QEC code with different distances. However, the
flag-bridge error correction circuits of a QEC code for
a specific quantum platform are ad hoc. Different cir-
cuits may be chosen based on the qubit topology, leading
to different error-syndrome patterns and in turn requir-
ing different decoding strategies. It is difficult to de-
sign heuristic decoding algorithms that can be applied to
various syndrome extraction circuits. Since flag-bridge
circuits are likely to be used for low-distance codes in
small experiments, a simple decoding solution is to cre-
ate a look-up table (LUT) for each QEC circuit. A LUT
decoder can find the most likely Pauli errors from a sin-
gle fault that leads to the observed syndromes and flags.
LUT decoders can be easily derived from the brute-force
checking procedure [13].
Another type of decoders are the neural-network (NN)
decoders [32–35]. They can provide high-speed decoding,
be adaptable to different error models, and be more easily
implemented on hardware. Moreover, a NN decoder can
be developed by training the network using only input-
output pairs without any knowledge of the QEC code,
making it favorable for flag-bridge circuits. For example,
the inputs of a NN decoder are the observed syndromes
and its outputs can be the actual physical errors that
have occurred. The implementation details of the LUT
decoder and the NN decoder can be found in Appendix A.
In this work, we design a simulation framework to au-
tomate the procedure of fault tolerance checking, LUT
6generation, and NN decoder training for given flag-bridge
syndrome extraction circuits of the Steane code. This
automation is desirable for demonstrating fault-tolerant
quantum error correction in near-term processors which
may have different geometrical interaction constraints.
IV. STEANE CODE ERROR CORRECTION ON
TWO DEVICE TOPOLOGIES
(a) (b)
FIG. 6: (a) The Surface-17 topology and (b) the IBM-20
topology, where each node represents a qubit, and each
edge indicates the connectivity between two qubits.
In this section, we show how to map the Steane code
error correction onto two different processors with lim-
ited connectivity using the proposed flag-bridge circuits,
namely, the Surface-17 transmon processor (Surface-
17) [18] and the IBM Q Tokyo processor (IBM-20) [17]
(Figure 6). Furthermore, we numerically analyze each
flag-bridge quantum error correction procedure under cir-
cuit level noise. This error model inserts depolarizing
errors after each operation in a flag-bridge circuit as fol-
lows: 1) each single-qubit gate is followed by a X, Y , or
Z with probability p/3; 2) each two-qubit gate is followed
by an element of {I,X, Y, Z}
⊗
2\{II} with probability
p/15; 3) the preparation or measurement in the Z basis
is flipped with probability p. The elementary Clifford
operations used in this simulation are preparation and
measurement in the Z basis, H and cnot gates. Other
operations need to be further decomposed into these el-
ementary operations. For example, each control-phase
gate is replaced by two H gates and one cnot gate.
A. Mapping
Many current and NISQ processors have geometrical
connectivity constraints, that is, each qubit can only in-
teract with a few neighbours. It is challenging or even im-
possible to directly perform existing flag-based quantum
error correction without adding more operations and/or
without losing fault tolerance. For example, the flag
circuit which measures one weight-4 Z-stabiliser of the
Steane code in Figure 1b cannot be directly executed on
the Surface-17 topology (Figure 6a) but can be supported
by the IBM-20 topology (Figure 6b). This is because
qubit s needs to interact with 5 qubits but in Surface-17
each qubit has at most 4 neighbours. The flag circuit
in Figure 1c can be performed on both processor topolo-
gies. However, a full round of error syndrome extraction
requires all the stabiliser generators of the Steane code
to be measured. The full syndrome extraction using only
these two flag circuits (Figure 1b and Figure 1c) can be
directly performed on the IBM-20 topology (e.g., a map-
ping in Figure 8a) but not on the Surface-17 topology.
4
1
7
5
3
6/-
-/6
2/-
-/2
(a) Steane-cl-L1
4
1
7
5
2
3
6
(b) Steane-c2-L1
FIG. 7: Mapping of the Steane code onto the Surface-17
topology, where the qubits labelled with numbers are
data qubits and the qubits in the colored blocks are
ancillas. (a) The mapping using the two-ancilla
flag-bridge circuits in Figures 1c and 4a in which only
one stabiliser is measured at a time; (b) The mapping
using the three-ancilla flag-bridge circuits in Figures 4b
and 5a that measure one and two stabilisers,
respectively.
5
4 7
1
2
3
6
(a) Steane-cl-L2
1
5
4
7
2
6
3
(b) Steane-c2-L2
1
5 4
7
2
6
3
(c) Steane-c3-L2
FIG. 8: Mapping of the Steane code onto the IBM-20
topology (a) using the flag-bridge circuits in Figures 1c
and 4a; (b) using the flag-bridge circuits in Figures 4b
and 5a; (c) using the four-ancilla flag-bridge circuit in
Figure 5b to measure three stabilisers simultaneously.
As mentioned above, all the flag-bridge circuits shown
in this paper are used to measure Z stabilisers, simi-
7lar circuits with the same ancillas can be derived for
measuring X-stabilisers. Figures 7 and 8 show exam-
ples of mapping the Steane code error correction using
the flag-bridge circuits onto the Surface-17 topology and
the IBM-20 topology, respectively.
In these mapping figures, the qubits in each red, blue,
or green block are the ancillas in each flag-bridge circuit
and they are used to measure the corresponding Z(X)-
stabiliser in the same color plaquette in Figure 2. The
flag-bridge qubits in the yellow block are used to mea-
sure the Z(X)-stabilisers in both red and green plaque-
ttes. The flag-bridge qubits in the gray block measure
the Z(X)-stabilisers in all three plaquettes. The X and
Z stabilisers are measured separately, more specifically,
one first measures all the stabilisers in one type and then
measures the other type. Furthermore, each of the flag-
bridge circuits for the Steane code error correction need
to be executed sequentially. On the Surface-17 topol-
ogy, one can measure all the stabilisers of the Steane
code one by one when using the mapping in Figure 7a.
Maximally two stabilisers can be measured in parallel in
this topology as shown in Figure 7b. In contrast, three
Z(X)-stabilisers can be measured at the same time on
the IBM-20 topology (Figure 8c).
The circuit characterization of one full round of syn-
drome extraction for the Steane code when using dif-
ferent mappings is shown in Table I. This characteriza-
tion includes the total number of ancilla qubits, the to-
tal number of operations and timesteps, and the number
of f-cnot and s-cnot gates. For comparison, we also
show these parameters of the rotated distance-3 surface
code (SC d=3). As shown in Table I, the circuits which
can measure more stabilisers simultaneously require less
operations and less timesteps. Moreover, though the
distance-3 surface code uses more ancilla qubits, it al-
ways needs less operations and less timesteps than the
Steane code.
# Ancillas # Operations # f-CNOTs # s-CNOTs # Timesteps
Steane-c1-L1 6 72 12 24 50
Steane-c1-L2 6 72 12 24 48
Steane-c2-L1 6 72 16 20 40
Steane-c2-L2 5 62 12 20 36
Steane-c3-L2 4 54 12 18 26
SC d=3 8 48 0 24 8
TABLE I: Comparison of the quantum error correction
circuits when different mappings are applied.
B. Numerics
We further compare different mapping circuits in terms
of their fault tolerance, which is analyzed by numerical
simulation under circuit level noise. For each point in
the numerics, 106 iterations of a full QEC cycle have
been run and confidence intervals at 99.9% are plotted.
Moreover, NN decoders are used for this comparison since
it has better performance than LUT decoders (see Fig-
ures 9a and 14). As shown in Figure 9, for the Steane
code, the circuits that can measure more stabilisers in
parallel have lower logical error rates, likely because they
consist of fewer operations and require fewer timesteps.
Moreover, when there are no idling errors (pI = 0 in Fig-
ure 9a) or a small probability of idling errors (pI = 0.01p
in Figure 9b), the Steane code can achieve similar per-
formance to, or even outperform, the distance-3 surface
code by parallelizing stabiliser measurements. This is
because the circuit for the surface code error correction
consists of more s-cnot gates than the QEC circuits that
can measure several stabilisers in parallel for the Steane
code. When idling errors are significant, we observe that
the circuit with fewer timesteps results in lower logical
error rates (as shown in Figures 9c and 9d for pI = 0.1p
and pI = p respectively).
V. OTHER APPLICATIONS OF THE
FLAG-BRIDGE CIRCUITS
In this section, we foresee some possible applications
of the flag-bridge circuits including both fault-tolerant
quantum error correction and fault-tolerant quantum
computation.
A. Flag-bridge QEC for the five-qubit code
Analogous to the flag circuits, the flag-bridge circuits
can also be applied to other distance-3 error correction
codes such as the J8, 3, 3K, J10, 4, 3K, J11, 5, 3K, J5, 1, 3K
codes, Hamming codes J2r − 1, 2r − 1− 2r, 3K, etc. In
this section, we consider the J5, 1, 3K code as an example.
This code has four stabilisers, which are cyclic permuta-
tions of XZZXI. Figure 10 shows the flag-bridge circuits
that can measure an XZZX stabiliser fault-tolerantly.
Each stabiliser of the 5-qubit code can be measured us-
ing these circuits up to data qubit permutation. Similar
circuits using three ancillas to measure one stabiliser are
also proposed in [13]. All these circuits have different
connectivity requirements. By selecting and combining
some of them, one can map the 5-qubit code error cor-
rection onto different qubit topologies. Figure 11 shows
the mapping of the 5-qubit code to the Surface-17 pro-
cessor topology using the two-ancilla flag-bridge circuits
and the IBM Q Melbourne (IBM-16) processor topology
using the three-ancilla flag-bridge circuits.
B. Flag-bridge circuits for FT computation
The geometrical interaction constraint in near-term
quantum processors has also limited the fault-tolerant
implementation of logical operations. For instance, a
fault-tolerant cnot gate in planar surface codes and
color codes in principle can be implemented transversally
in a 3D structure, that is, performing pair-wise cnot
81 1.5 2·10−3
1
2
3
·10−3
Physical error probability
L
og
ic
al
er
ro
r
ra
te
NND, pI = 0
Steane-c1-L1
Steane-c1-L2
Steane-c2-L1
Steane-c2-L2
Steane-c3-L2
distance-3 SC
(a)
1 1.5 2·10−3
1
2
3
·10−3
Physical error probability
L
og
ic
al
er
ro
r
ra
te
NND, pI = 0.01p
Steane-c1-L1
Steane-c1-L2
Steane-c2-L1
Steane-c2-L2
Steane-c3-L2
distance-3 SC
(b)
0.5 1 1.5·10−3
0
2
4
·10−3
Physical error probability
L
og
ic
al
er
ro
r
ra
te
NND, pI = 0.1p
Steane-c1-L1
Steane-c1-L2
Steane-c2-L1
Steane-c2-L2
Steane-c3-L2
distance-3 SC
(c)
0.5 1 1.5·10−3
0
5 · 10−2
0.1
Physical error probability
L
og
ic
al
er
ro
r
ra
te
NND, pI = p
Steane-c1-L1
Steane-c1-L2
Steane-c2-L1
Steane-c2-L2
Steane-c3-L2
distance-3 SC
(d)
FIG. 9: Numerical simulation of the Steane code error correction based on different flag-bridge circuits using neural
network decoders (NND). The circuit level noise (p1 = p2 = pM ) with (pI 6= 0) or without idling errors (pI 6= 0).
gates between data qubits of the two lattices. However,
this transversal cnot is not realizable in near-term quan-
tum technologies because of the local qubit connectivity
limitation in a 2D architecture. Measurement-based pro-
tocols such as lattice surgery [36, 37] and code deforma-
tion [38, 39] have been proposed to comply with the 2D
local interaction constraint. Figures 12 and 13 show the
qubit layouts for performing lattice-surgery-based oper-
ations on the distance-3 surface code and the distance-3
color code (the Steane code), respectively. The details
of implementing logical operations by lattice surgery can
be found in [36, 37].
As shown in Figure 12, the merge operations can be
directly performed on a 2D grid topology. As mentioned
previously, the stabiliser measurement of surface codes
can be realized by only using the one-ancilla circuit sim-
ilar to Figure 1a. However, one ancilla qubit (the circled
one in Figure 12b) is used by two stabilisers from dif-
ferent lattices during the split operation. One may have
to measure these two stabilisers sequentially, which leads
to more timesteps and in turn may result in higher log-
ical error rates. To preserve parallelism of the stabiliser
measurement, we propose to use the qubit layout in Fig-
ure 12c. By using this layout, one can measure all the
stabilisers in parallel when splitting lattices since they
no longer share ancillas. One can also perform the merge
operation by replacing the original syndrome extraction
circuit using one ancilla with the proposed flag-bridge
circuits using two ancillas (Figure 1c) where ancillas are
connected by dash lines in Figure 12c . Similar mapping
can be applied to other code-deformation-based opera-
tions on surface codes.
Furthermore, lattice-surgery-based operations for the
Steane code in Figure 13a cannot be directly realized in
a 2D grid topology. Similar to the mapping in Figure 7b,
one can map these operations fault-tolerantly using the
three-ancilla flag-bridge circuits as shown in Figure 13b.
Compared to the distance-3 surface code, the Steane code
can achieve Clifford gates transversally. Moreover, it re-
quires fewer qubits for both FT error correction and FT
computation, which may be preferable for demonstrating
fault tolerance in small experiments.
VI. DISCUSSION AND CONCLUSION
We have shown that the flag circuits can be phrased as
one using encoded ancillas in an Jm, p, 1K code. Based
on this formulation, we proposed a flag-bridge approach
9s |0〉
f |+〉 X
Z
(a)
f |0〉
s |+〉
Z
X
(b)
f |0〉
s |+〉
Z
X
(c)
f1 |0〉
f2 |0〉
s |+〉
Z
Z
X
(d)
FIG. 10: Fault-tolerant circuits for performing an
XZZX-check: (a), (b), (c) using 2 ancillas but
requiring different connectivity; (d) using three ancillas,
similar circuits can be generated by re-distributing the
s-cnot gates for each weight-4 check to different
ancillas as mentioned in Section III.
43
5
2
1
(a)
43
5
2
1
(b)
FIG. 11: Mapping of the 5-qubit code onto (a) the
Surface-17 topology by using the two-ancilla flag-bridge
circuits in Figure 10 and (b) the IBM-16 topology using
the three-ancilla circuit in Figure 10d.
to perform fault-tolerant quantum error correction for
distance-3 codes on connectivity-constrained near-term
quantum processors with low overhead. Furthermore,
we mapped the Steane code error correction onto two
current qubit topologies using the flag-bridge circuits.
The numerical simulation results have shown that, the
QEC circuits that can measure more stabilisers in paral-
lel achieve lower logical error rates, providing insights for
fabricating processors with more connectivity. Moreover,
we also showed that flag-bridge circuits can be applied
to the 5-qubit code and lattice-surgery-based operations
for the surface codes and the Steane code. In addition,
we have observed that the Steane code implementation
that uses fewer qubits even outperforms the distance-3
surface code when idling errors occur with low proba-
bility. The Steane code also allows transversal Clifford
gates, which may make it a better candidate than the
distance-3 surface code for demonstrating fault tolerance
in small experiments. However, the numerics in this work
(a) (b) (c)
FIG. 12: Mapping lattice surgery-based operations for
the distance-3 surface code using flag-bridge circuits.
Each red (blue) plaquette represents a weight-4 or
weight-2 X(Z)-stabiliser. Data qubits are on the
vertices and ancilla qubits are on the plaquettes. (a)
and (b) Initial layouts for performing a merge and a
split operation using lattice surgery, respectively. (c)
The layout after mapping using the two-ancilla
flag-bridge circuits.
(a)
5
5
4
7
4
7
2
2
1
3
1
3
6
6
(b)
FIG. 13: Mapping lattice surgery-based operations for
the Steane code using flag-bridge circuits. (a) Initial
layout, where the gray plaquettes only contain one type
of stabilisers, depending on which joint measurement
needs to be performed. Data qubits are on the vertices
and ancilla qubits are on the plaquettes. (b) Mapping
to a grid topology similar to Figure 7b.
were carried out with Pauli errors, it will be interesting
to test these circuits using more realistic error models.
Furthermore, the mapping procedure in this work was
hand-optimized. Future work will focus on automating
the fault-tolerant mapping of flag-bridge quantum error
correction onto given processors. Besides, we also need
to investigate the extensibility and scalability to higher
distance codes and fault-tolerant computation.
ACKNOWLEDGMENTS
The authors would like to thank Ben Criger for enlight-
ening discussions on this project and feedback on the
10
manuscript. We also thank Yang Wang and Xiaotong
Ni for useful discussions on the implementation of er-
ror decoders. LLL acknowledges funding from the China
Scholarship Council. CGA acknowledges support from
the Intel Corporation.
Appendix A: Implementation of LUT and NN
decoders
Based on the FT QEC procedure for distance-3 codes
in Section III, decoding is only needed when two rounds
of syndrome extraction (SE) are performed (the first
round has non-trivial syndromes or flags). If there is only
non-trivial syndromes (no flags) in the first round, then
the decoders will only decode using the measurement re-
sults in the second round. If there is any non-trivial flag
in the first round, then the decoders will decode using
these flags and the measurement results in the second
round. For the measurement information in the second
round, the simple LUT decoder only considers the re-
sults of syndrome qubits, which is enough for correct-
ing all the errors caused by one fault. In contrast, the
NN decoder also takes the flags of the second round into
account. This means the NN decoder could potentially
correct some errors caused by more faults, outperforming
the LUT decoder.
0.5 1 1.5·10−3
0
1
2
3
·10−3
Physical error probability
L
og
ic
al
er
ro
r
ra
te
LUTD, pI = 0
Steane-c1-L1
Steane-c1-L2
Steane-c2-L1
Steane-c2-L2
Steane-c3-L2
distance-3 SC
FIG. 14: Performance of the LUT decoder for the
Steane code under circuit level noise without idling
errors.
Loss
function
Hidden
layers
Activation function
Optimizer Learning
rate
Batch
size
PER Samples
Output
layer
hidden
layer
cross-
entropy
3 sigmoid
ReLU
(tanh)
Adam
(Nadam)
0.002 50 ∼ 0.01 105
TABLE II: The implementation details of the NN
decoder.
The LUT decoder: As mentioned previously, we use
a brute-force search to check the fault tolerance of flag-
bridge circuits. After this search, all the errors from one
single fault and the corresponding syndrome-flag (SF)
string are collected. For FT flag-bridge circuits, these
error-SF pairs can be directly used to design a LUT de-
coder. Two look-up tables need to be created. One is
used for the case where only syndromes are observed
in the first round of SE with a size 2ms , ms is the
total number of syndrome qubits in the QEC circuit
C = {c(g1), c(g2), · · · , c(gr)}. Note that if the same an-
cilla qubits are re-used in different cg, they are still con-
sidered as different syndrome qubits, similarly for flag
qubits. The other table is to decode for the case where
flags are raised in the first round of SE, which has a size
of
∑
i 2
mfi2ms , mfi is the total number of flag qubits
in cgi . The LUT decoder is designed to correct all sin-
gle faults, but not to correct the most likely two faults
correspond to measured syndromes. The performance
of different flag-bridge circuits for the Steane code using
LUT decoders is shown in Figure 14. As can be seen,
the QEC circuits that can achieve more parallelism of
stabiliser measurement have lower logical error rates.
The NN decoder: Decoding can be seen as a classi-
fication problem, that is, given the observed syndromes,
the decoder identifies the error or the logical coset of the
error that has occurred . It has been shown that neu-
ral networks are versatile tools for decoding topological
quantum error correction codes [32–35]. The inputs xi for
a neural network decoder are the syndromes (and flags
for flag QEC). In this paper, two rounds of syndromes
and flags will be collected when using the flag-bridge er-
ror correction for distance-3 codes. Therefore, the size of
input layer will be 2×m, m is the total number of syn-
drome and flag-bridge qubits. In this work, the outputs
yi are the suggested physical errors which can result in
the given syndromes and flags. For a CSS code with n
data qubits, the size of output layer is set to be 2 × n,
which can describe whether a X or/and a Z error has oc-
curred on each data qubit. The neural network will find
an approximate function f : x→ y to describe the input-
output relation from the set of training data {(xi, yi)}.
Note for large-distance codes, it is more efficient to use
logical errors as outputs and a simple decoder (e.g., LUT
decoder) is required to generate the logical error infor-
mation.
In this work, a simple NN decoder using the Tensorflow
library [40] is developed to analyze the fault tolerance of
different flag-bridge circuits. We use the ‘sigmoid’ activa-
tion function for the output layer and 105 syndrome-error
pairs at physical error rate (PER) around 0.01 are sam-
pled for each training, more details of the designed NN
decoder are described in Table II. Since the focus of this
work is to evaluate the flag-bridge quantum error correc-
tion, we leave the performance and speed optimization of
NN decoders for future work.
11
[1] J. Preskill, Quantum 2, 79 (2018).
[2] J. Kelly, A Preview of Bristlecone, Googles New Quantum
Processor, News from Google AI (Google LLC, 2018).
[3] W. Knight, IBM Raises the Bar with a 50-Qubit Quan-
tum Computer, News (MIT Technology Review, 2018).
[4] J. Hsu, CES 2018: Intel’s 49-Qubit Chip Shoots for
Quantum Supremacy, General technology blog (IEEE
Spectrum, 2018).
[5] R. Barends, J. Kelly, A. Megrant, A. Veitia, D. Sank,
E. Jeffrey, T. C. White, J. Mutus, A. G. Fowler,
B. Campbell, et al., Nature 508, 500 (2014).
[6] C. Hempel, C. Maier, J. Romero, J. McClean, T. Monz,
H. Shen, P. Jurcevic, B. P. Lanyon, P. Love, R. Babbush,
et al., Phys. Rev. X 8, 031022 (2018).
[7] C. Kokail, C. Maier, R. van Bijnen, T. Brydges, M. Joshi,
P. Jurcevic, C. Muschik, P. Silvi, R. Blatt, C. Roos, et al.,
Nature 569, 355 (2019).
[8] X. Fu, L. Riesebos, L. Lao, C. Almudever, F. Sebastiano,
R. Versluis, E. Charbon, and K. Bertels, in Proceed-
ings of the ACM International Conference on Computing
Frontiers (CF) (ACM, 2016) pp. 323–330.
[9] X. Fu, M. Rol, C. Bultink, J. Van Someren,
N. Khammassi, I. Ashraf, R. Vermeulen, J. De Sterke,
W. Vlothuizen, R. Schouten, et al., in Proceedings of
the 50th Annual IEEE/ACM International Symposium
on Microarchitecture (ACM, 2017) pp. 813–825.
[10] P. W. Shor, in Proceedings of 37th Conference on Foun-
dations of Computer Science (IEEE, 1996) pp. 56–65.
[11] A. M. Steane, Phys. Rev. Lett. 78, 2252 (1997).
[12] E. Knill, Phys. Rev. A 71, 042322 (2005).
[13] T. J. Yoder and I. H. Kim, Quantum 1, 2 (2017).
[14] R. Chao and B. W. Reichardt, Phys. Rev. Lett. 121,
050502 (2018).
[15] C. Chamberland and M. E. Beverland, Quantum 2, 53
(2018).
[16] B. W. Reichardt, arXiv:1804.06995 (2018).
[17] IBM, “Quantum experience,” (2017).
[18] R. Versluis, S. Poletto, N. Khammassi, B. Tarasinski,
N. Haider, D. Michalak, A. Bruno, K. Bertels, and L. Di-
Carlo, Phys. Rev. Applied 8, 034021 (2017).
[19] Rigetti, “Regetti forest,” (2018).
[20] D. P. DiVincenzo and P. Aliferis, Phys. Rev. Lett. 98,
020501 (2007).
[21] A. G. Fowler, M. Mariantoni, J. M. Martinis, and A. N.
Cleland, Phys. Rev. A 86, 032324 (2012).
[22] D. Riste, S. Poletto, M.-Z. Huang, A. Bruno, V. Vester-
inen, O.-P. Saira, and L. DiCarlo, Nature communica-
tions 6, 6983 (2015).
[23] J. Kelly, R. Barends, A. G. Fowler, A. Megrant, E. Jef-
frey, T. C. White, D. Sank, J. Y. Mutus, B. Campbell,
Y. Chen, et al., Nature 519, 66 (2015).
[24] L. Lao, B. van Wee, I. Ashraf, J. van Someren, N. Kham-
massi, K. Bertels, and C. Almudever, Quantum Science
and Technology 4, 015005 (2019).
[25] G. Li, Y. Ding, and Y. Xie, in Proceedings of the Twenty-
Fourth International Conference on Architectural Sup-
port for Programming Languages and Operating Systems
(ACM, 2019) pp. 1001–1014.
[26] S. S. Tannu and M. K. Qureshi, in Proceedings of the
Twenty-Fourth International Conference on Architec-
tural Support for Programming Languages and Operating
Systems (ACM, 2019) pp. 987–999.
[27] Y. Shi, N. Leung, P. Gokhale, Z. Rossi, D. I. Schus-
ter, H. Hoffmann, and F. T. Chong, in Proceedings of
the Twenty-Fourth International Conference on Architec-
tural Support for Programming Languages and Operating
Systems (ACM, 2019) pp. 1031–1044.
[28] L. Lao, D. M. Manzano, H. van Someren, I. Ashraf, and
C. G. Almudever, arXiv:1908.04226 (2019).
[29] D. Gottesman, arXiv:9807006 (1998).
[30] A. G. Fowler, Quantum Information & Computation 15,
145 (2015).
[31] G. Duclos-Cianci and D. Poulin, Phys. Rev. Lett. 104,
050504 (2010).
[32] S. Krastanov and L. Jiang, Scientific reports 7, 11003
(2017).
[33] S. Varsamopoulos, B. Criger, and K. Bertels, Quantum
Science and Technology 3, 015004 (2017).
[34] P. Baireuther, T. E. O’Brien, B. Tarasinski, and C. W.
Beenakker, Quantum 2, 48 (2018).
[35] X. Ni, arXiv:1809.06640 (2018).
[36] C. Horsman, A. G. Fowler, S. Devitt, and R. Van Meter,
New Journal of Physics 14, 123011 (2012).
[37] A. J. Landahl and C. Ryan-Anderson, arXiv:1407.5103
(2014).
[38] H. Bomb´ın and M. A. Martin-Delgado, Journal of Physics
A: Mathematical and Theoretical 42, 095302 (2009).
[39] C. Vuillot, L. Lao, B. Criger, C. Garc´ıa Almude´ver,
K. Bertels, and B. M. Terhal, New Journal of Physics
21, 033028 (2019).
[40] M. Abadi, P. Barham, J. Chen, Z. Chen, A. Davis,
J. Dean, M. Devin, S. Ghemawat, G. Irving, M. Isard,
et al., in 12th {USENIX} Symposium on Operating Sys-
tems Design and Implementation ({OSDI} 16) (2016) pp.
265–283.
