Fault-tolerant quantum error correction using error weight parities by Tansuwannont, Theerapat & Leung, Debbie
Fault-tolerant quantum error correction using error weight parities
Theerapat Tansuwannont1, ∗ and Debbie Leung2, 3, †
1Institute for Quantum Computing and Department of Physics and Astronomy,
University of Waterloo, Waterloo, Ontario, N2L 3G1, Canada
2Institute for Quantum Computing and Department of Combinatorics and Optimization,
University of Waterloo, Waterloo, Ontario, N2L 3G1, Canada
3Perimeter Institute for Theoretical Physics, Waterloo, Ontario, N2L 2Y5, Canada
In quantum error correction using imperfect primitives, errors of high weight arising from a few
faults are major concerns since they might not be correctable by the quantum error correcting
code. Fortunately, some errors of different weights are logically equivalent and the same correction
procedure is applicable to all equivalent errors, thus correcting high-weight errors is sometimes
possible. In this work, we introduce a technique called weight parity error correction (WPEC)
which can correct Pauli error of any weight in some stabilizer codes provided that the parity of
the weight of the error is known. We show that the technique is applicable to concatenated codes
constructed from the [[7, 1, 3]] Steane code or the [[23, 1, 7]] Golay code. We also provide a fault-
tolerant error correction protocol using WPEC for the [[49, 1, 9]] concatenated Steane code which
can correct up to 3 faults and requires only 2 ancillas.
PACS numbers: 03.67.Pp
I. INTRODUCTION
One crucial component for large-scale quantum com-
puters is fault-tolerant error correction (FTEC), which
suppresses error propagation throughout the circuits.
An arbitrarily small logical error rate can be achieved
through code concatenation, given that the physical error
rate is below some constant threshold value [1–5]. How-
ever, increasing overheads are needed for decreasing logi-
cal error rate [6–9]. Conventional FTEC schemes require
many ancillas during error syndrome measurements. For
example, the Shor-style [1, 10] and the Knill-style [11]
error corrections, which apply to any stabilizer code, re-
quire as many ancillas as the maximum weight of the sta-
bilizer generators and twice the blocklength, respectively.
Steane-style error correction [12, 13] which applies to any
CSS code requires one code block of ancillas.
Recently, several FTEC schemes that use only a few
ancillas and are applicable to the [[7, 1, 3]] Steane code [14]
have been proposed. The scheme due to Yoder and Kim
for the [[7, 1, 3]] code uses 2 ancillas (9 qubits in total)
[15]. Their ideas are further developed to a “flag FTEC”
scheme which, for the [[7, 1, 3]] code, also uses 2 ancillas
[16]. A flag FTEC scheme for any [[n, k, d]] stabilizer code
requires d + 1 ancillas [17], where the schemes for some
specific code families may require fewer [16, 18–21]. The
flag technique that uses a few ancillas to detect high-
weight errors can also be applied to various fault-tolerant
schemes [22–29]. Another FTEC scheme applicable to
the [[7, 1, 3]] code was proposed by Reichardt; the scheme
extracts several syndrome bits at once and requires no
ancillas, provided that there are at least two code blocks
(so at least 14 qubits are required in total) [30].
∗ ttansuwannont@uwaterloo.ca
† wcleung@uwaterloo.ca
In order to achieve an arbitrarily low error rate through
code concatenation, the FTEC scheme used with the
code must be modified accordingly. One way to do this
is replacing all physical qubits with code blocks and re-
placing all physical gates with corresponding logical gates
[5]. For the [[7, 1, 3]] code, each qubit (including each an-
cilla qubit) required in an FTEC scheme will become a
block of 7 physical qubits in the modified scheme. Fol-
lowing this modification, the schemes in [15, 16] applied
to the [[49, 1, 9]] concatenated Steane code will require 63
qubits in total. Meanwhile, the scheme in [30] requires 98
qubits in total, encoding 2 logical qubits. Note that the
maximum weight for the stabilizer generators increases
quickly with concatenation. These difficulties motivate
our main question: how to reduce the number of ancillas
required for an FTEC scheme for a concatenated code?
In this paper, we introduce a technique called weight
parity error correction (WPEC) and construct an FTEC
scheme for the [[49, 1, 9]] concatenated Steane code us-
ing only two ancilla qubits. The scheme relies on the
fact that, for the [[7, 1, 3]] code, errors with the same syn-
drome and weight parity differ by the multiplication of
some stabilizer; these errors are thus logically equivalent
and need not be distinguished from one another. There-
fore, error correction on each subblock of 7 qubits in the
[[49, 1, 9]] code can be accomplished using only two ingre-
dients: the error syndrome and the weight parity of error
in each subblock. Most importantly, the weight parity for
each subblock of 7 qubits in the [[49, 1, 9]] can be obtained
from the full syndrome measurement. Using this idea in
conjunction with 2 ancilla qubits, our FTEC protocol for
the [[49, 1, 9]] code can correct up to 3 faults. As a result,
our protocol can suppress the error rate from p to O(p4)
using 51 qubits in total.
The paper is organized as follows: In Section II, we
observe the aforementioned equivalence between errors of
any weight with the same syndrome and weight parity,
ar
X
iv
:2
00
6.
03
06
8v
1 
 [q
ua
nt-
ph
]  
4 J
un
 20
20
2and describe WPEC. In Section III, we provide sufficient
conditions for WPEC, then we provide syndrome extrac-
tion circuits and an FTEC protocol for the [[49, 1, 9]] con-
catenated Steane code using only two ancilla qubits. In
Section IV, WPEC is extended to the [[23, 1, 7]] Golay
code and concatenated Steane codes with more than 2
levels of concatenation. Last, we discuss our results and
directions for future works in Section V.
II. WEIGHT PARITY ERROR CORRECTION
FOR THE STEANE CODE
The Steane code [14], also known as the [[7, 1, 3]] code,
is a quantum error correcting code that encodes 1 logi-
cal qubit into 7 physical qubits and can correct any er-
ror on up to 1 qubit. It has several desirable properties
for fault-tolerant quantum computation, e.g., logical Clif-
ford operations are transversal [1]. The Steane code is a
code in the Calderbank-Shor-Steane (CSS) code family
[14, 31] where X-type and Z-type errors can be detected
and corrected separately. The Steane code in the stabi-
lizer formalism can be constructed from the parity check
matrix of the classical [7, 4, 3] Hamming code through the
CSS construction [32]. In addition, it is known that any
classical Hamming code can be rearranged into a cyclic
code, a binary linear code in which any cyclic shift of a
codeword is also a codeword [33]. We can describe the
Steane code in cyclic form with the following stabilizer
generators:
gx1 :X I X X X I I, g
z
1 :Z I Z Z Z I I,
gx2 : I X I X X X I, g
z
2 : I Z I Z Z Z I,
gx3 : I I X I X X X, g
z
3 : I I Z I Z Z Z.
(1)
The generators of a stabilizer code define not only the
codespace, but also the measurements that give rise to
the error syndrome. When these measurements are im-
perfect, different sets of generators for the same code can
have different fault-tolerant properties. The use of the
Steane code in cyclic form gives some advantages in dis-
tinguishing high-weight errors in consecutive form [19]
(see Section V for more details). We can choose the logi-
cal X and logical Z operators to be X⊗7S and Z⊗7T for
any stabilizer operators S, T . With this convention, we
state the following crucial property of the Steane code
that goes into our construction. It can be proved in
many ways, including exhaustive verification. We leave
the proof to the interested readers.
Fact 1. Let M be any Z-type operator (a tensor product
of Is and Zs) defined on 7 qubits. Suppose M commutes
with all X-type generators of the [[7, 1, 3]] code. If M has
even weight, then it is a logical I; otherwise, if M has
odd weight, then it is a logical Z.
For a Pauli error E on a block of 7 qubits, the syndrome
is a 6-bit string denoted by s(E) = (sx|sz) where sx, sz ∈
Z32. The i-th bit of sx (or sz) is 0 if E commutes with gxi
(or gzi ), and 1 if E anticommutes with g
x
i (g
z
i ). If E occurs
to a codeword of the Steane code, s(E) corresponds to
the outcomes of measuring the six generators (0 and 1
correspond to +1 and −1 outcomes, respectively). The
Steane code is a perfect CSS code of distance 3 meaning
that for each sx, (sx|000) is the syndrome of a unique
weight-1 Z-type error, which we denote as Ezwt-1(sx), and
similarly each (000|sz) is the syndrome of a unique X-
type error. For CSS codes, the X-type and Z-type error
correction are independent of one another. Furthermore,
we focus on CSS codes in which the X and Z generators
have the same form, and the same method applies to
both types of error correction. So we focus on Z errors
for simplicity. Since Z-type errors have trivial sz, we
focus on sx from now on.
With the above notations, consider the following sim-
ple error correction procedure on the Steane code: if the
syndrome is (sx|000), do nothing if sx is trivial, apply
Ezwt-1(sx) otherwise. We observe that if the syndrome
is caused by a Z-type error, then the procedure outputs
the encoded data transformed by a logical I or logical Z.
This is because the actual Z-type error combined with
the correction remains Z-type and commutes with all of
gx1,2,3, so the conclusion follows from Fact 1.
If a codeword is corrupted by an arbitrary Z-type er-
ror E, the above procedure always recovers the codeword,
but sometimes with an undesirable logical Z error. The
technique of weight parity error correction, to be devel-
oped next, is a revised procedure that will always cor-
rect the error E, but it requires knowing whether E has
odd or even weight. Measuring the error weight parity
should not be done on a single layer of Steane code since
it measures a logical operator on the Steane code. For-
tunately, the parity information can be safely learnt for
the constituent blocks when we concatenate the Steane
code with itself. We will describe these ideas in details in
the rest of this section, and apply them for fault-tolerant
error correction in the next section.
First we use Fact 1 to show that Z-type errors with the
same syndrome and the same weight parity (whether odd
or even) differ by the multiplication of some stabilizer.
Claim 1. Logical equivalence of errors with the same
syndrome and weight parity for the [[7, 1, 3]] code
Suppose E1, E2 are arbitrary Z-type errors (of any
weights) on the [[7, 1, 3]] code with the same syndrome.
Then, E1 and E2 have the same weight parity iff E1 =
E2S for some stabilizer S.
Proof. Let w1, w2 be the weights of E1, E2, respectively.
Let N = E1E2 (so E2 = E1N as E1 = E
†
1). The weight
of N is equal to w1 + w2 − 2k where k is the number of
qubits supported by both E1 and E2. As N commutes
with all of gx1,2,3, from Fact 1, N is a logical I if and only
if w1 + w2 − 2k is even (when E1 and E2 have the same
weight parity).
Second, we use Claim 1 to provide a method for er-
ror correction of Z-type error of arbitrary weight on the
Steane code, if the weight parity of the error is known:
3Definition 1. Weight parity error correction (WPEC)
for the [[7, 1, 3]] code
Suppose a Z-type error E occurs to a codeword of
the [[7, 1, 3]] code. Let sx and w be the syndrome and
the weight of E, Ezwt-1(sx) be the weight-1 Z-type oper-
ator with syndrome sx, and E
z
wt-2(sx) be any weight-2
Z-type operator with syndrome sx, respectively. The fol-
lowing procedure is called weight parity error correction
(WPEC):
1. If sx is trivial, do nothing if w is even, or apply any
logical Z if w is odd.
2. If sx is nontrivial, apply E
z
wt-1(sx) if w is odd, or
apply Ezwt-2(sx) if w is even.
WPEC always returns the original codewords because
in each case, the error E and the correction operation
have the same syndrome and weight parity, so by Claim 1,
the correction is logically equivalent to E.
WPEC allows us to correct high-weight errors in the
Steane code, but we need to know the weight parity of
the error. The weight parity is the outcome of measur-
ing Z⊗7, so learning the weight parity is equivalent to a
logical Z measurement, which destroys the superposition
of the logical |0〉 and |1〉. Fortunately, there is a setting
in which the weight parity can be obtained without af-
fecting the encoded data. Consider code concatenation in
which each qubit of an error correcting code C2 is encoded
into another quantum error correcting code C1. If C1 is
chosen to be the Steane code, the weight parity of each
codeblock can potentially be learnt from the syndrome of
C2. We will develop WPEC for the concatenated Steane
code in the rest of this section and show the advantage
in the context of fault tolerance in the next section.
Consider code concatenation using two Steane codes
in cyclic form. The resulting code which is a [[49, 1, 9]]
code can be described by 48 stabilizer generators. The
first group of 42 generators, called 1st-level generators,
have the form gxi ⊗I⊗42, gzi ⊗I⊗42, I⊗7⊗gxi ⊗I⊗35, I⊗7⊗
gzi ⊗ I⊗35, . . . , I⊗42 ⊗ gxi , I⊗42 ⊗ gzi for i = 1, 2, 3. The
remaining 6 of these generators, called 2nd-level genera-
tors, have the form
g˜x1 : X I X X X I I, g˜
z
1 : Z I Z Z Z I I,
g˜x2 : I X I X X X I, g˜
z
2 : I Z I Z Z Z I,
g˜x3 : I I X I X X X, g˜
z
3 : I I Z I Z Z Z,
(2)
where I = I⊗7,X = X⊗7, and Z = Z⊗7. The logical
X and logical Z operators can be chosen to be X¯ =
X⊗49S and Z¯ = Z⊗49T for any stabilizer operators S, T .
Relevant parts of the error syndrome corresponding to
the 1st-level and the 2nd-level generators will be called
1st-level and 2nd-level syndromes, respectively.
Let us consider error correction on the [[49, 1, 9]] code
and assume for now that error syndromes are reliable
(which can be obtained from repetitive measurements).
First, consider a simple motivating example, and suppose
that a Z-type error E acts nontrivially on at most one
subblock of 7-qubit code. In order to perform WPEC, the
weight parity of E and the subblock in which E occurs
must be known. Suppose that E has nontrivial 1st-level
syndrome. The subblock in which E occurs is actually
the subblock whose corresponding 1st-level syndrome is
nontrivial, while the weight parity of E is a measurement
result from a 2nd-level generator which acts nontrivially
on that subblock (note that the 2nd-level generator must
acts nontrivially on all qubits in such subblock, thus a
choice of 2nd-level generators is important). Now, sup-
pose that E has trivial 1st-level syndrome. The subblock
in which E occurs can no longer be identified by the 1st-
level syndrome. Fortunately, since the 2nd-level Steane
code (C2) is a distance-3 code, it can identify if any of
the 7 subblocks of [[7, 1, 3]] code (the C1 subblocks) has
a Z-type error logically equivalent to Z⊗7, thus provid-
ing the weight parity for each subblock of [[7, 1, 3]] code.
That is, if E has trivial 1st-level syndrome and its weight
is odd, the weight parity of E and the subblock in which
E occurs can be determined using only the 2nd-level
syndrome. (If E has trivial 1st-level syndrome and has
even weight, it is a stabilizer and no error correction is
needed.)
If the Z-type error is more general and may act on mul-
tiple subblocks, the 2nd-level syndrome may not provide
the weight parities of the subblocks. Instead, we con-
sider only Z-type errors that arise from a small number
of faults in specially designed generator measurements.
We will show that for these errors, the weight parity for
each subblock can be determined by the 2nd-level syn-
drome along with the information whether each subblock
has trivial 1st-level syndrome or not.
In particular, let block parity px ∈ Z72 be a bitstring,
where each bit is the weight parity of the Z error in one
subblock, and 0 and 1 represent even and odd weights,
respectively. Also, define the triviality of a subblock to
be 0 or 1 if the subblock has trivial or nontrivial 1st-
level syndrome, and let block triviality τx ∈ Z72 be a 7-bit
string in which the i-th bit represents the triviality of
the i-th subblock. If the block parity can be accurately
determined using the 2nd-level syndrome together with
the block triviality (we will elaborate how this can be
done later), then we can blockwisely perform WPEC as
described in Definition 1 by using the 1st-level syndrome
and the weight parity of each subblock.
In this work, we develop an FTEC protocol that uses
WPEC to correct high-weight errors arising from up to
3 faults. As an example, consider the measurement of
g˜z1 using the circuit depicted in Fig. 1a. Here we as-
sume that a fault from any two-qubit gate can cause
any two-qubit Pauli errors on the qubits where the gate
acts nontrivially, and X-type and Z-type errors can be
detected separately. Thus, we may assume that high-
weight errors arising from a single CNOT fault is of the
form PIZZZII, IIPZZII, IIIPZII, or IIIIPII, where
Z = Z⊗7, P = I⊗7−m ⊗ Z⊗m, and m ∈ {1, . . . , 7} (see
the analysis of possible errors in [19] for more details). It
is not hard to find 2nd-level syndrome, block triviality,
4(a)
(b)
FIGURE 1: (a) An example of circuit for measuring gen-
erator g˜z1 = ZIZZZII. Here we only display the sub-
blocks in which the operator acts nontrivially (the 1st,
2nd, 3rd, and 4th subblocks in the figure correspond to
the 1st, 3rd, 4th, and 5th subblocks of g˜z1). A circuit
for measuring X-type operator such as g˜x1 = XIXXXII
can be obtained by replacing all CNOT gates with the
gate illustrated in (b).
and block parity corresponding to each possible error.
For example, error PIZZZII with m = 6 anticommutes
with gx1 and g˜
x
1 , and commutes with the other generators.
Thus, its corresponding 2nd-level syndrome, block trivi-
ality, and block parity are (1, 0, 0), (1, 0, 0, 0, 0, 0, 0), and
(0, 0, 1, 1, 1, 0, 0), respectively. Table I displays all possi-
ble high-weight errors arising from a single fault during
g˜z1 measurement and their corresponding 2nd-level syn-
drome, block triviality, and block parity. Note that ex-
cept for the first and the last row (with errors differing
by multiplication of a stabilizer), each row has a unique
combination of 2nd-level syndrome and block triviality,
so the block parity can be determined from the table.
Since the 2nd-level syndrome and the block triviality can
in turns be obtained from the generator measurements,
all possible errors arising from a single CNOT fault dur-
ing the measurement of g˜z1 can be corrected using WPEC.
In addition, observe that ZIZZZII and I⊗7 are equiva-
lent up to a multiplication of g˜z1 but their block parities
are different. Here we can see that multiplying an error
with some 2nd-level generators may change its block par-
ity, but its 2nd-level syndrome and block triviality (which
is deduced from its 1st-level syndrome) remain the same.
In this case, WPEC is still applicable. We say that block
parities are equivalent whenever they can be transformed
to one another by multiplying the corresponding errors
with some stabilizer.
In an actual fault-tolerant protocol, we want to distin-
guish all possible high-weight errors arising from various
Form of
m
2nd-level block
block parity
error syndrome triviality
PIZZZII
7 (0,0,0) (0,0,0,0,0,0,0) (1,0,1,1,1,0,0)
2,4,6 (1,0,0) (1,0,0,0,0,0,0) (0,0,1,1,1,0,0)
1,3,5 (0,0,0) (1,0,0,0,0,0,0) (1,0,1,1,1,0,0)
IIPZZII
7 (1,0,0) (0,0,0,0,0,0,0) (0,0,1,1,1,0,0)
2,4,6 (0,0,1) (0,0,1,0,0,0,0) (0,0,0,1,1,0,0)
1,3,5 (1,0,0) (0,0,1,0,0,0,0) (0,0,1,1,1,0,0)
IIIPZII
7 (0,0,1) (0,0,0,0,0,0,0) (0,0,0,1,1,0,0)
2,4,6 (1,1,1) (0,0,0,1,0,0,0) (0,0,0,0,1,0,0)
1,3,5 (0,0,1) (0,0,0,1,0,0,0) (0,0,0,1,1,0,0)
IIIIPII
7 (1,1,1) (0,0,0,0,0,0,0) (0,0,0,0,1,0,0)
2,4,6 (0,0,0) (0,0,0,0,1,0,0) (0,0,0,0,0,0,0)
1,3,5 (1,1,1) (0,0,0,0,1,0,0) (0,0,0,0,1,0,0)
I⊗7 - (0,0,0) (0,0,0,0,0,0,0) (0,0,0,0,0,0,0)
TABLE I: A table of all possible forms of data er-
rors arising from a single fault occurred during syn-
drome measurement using a circuit in Fig. 1a (where
P = I⊗7−m ⊗ Z⊗m). The block parity corresponding to
each form of errors can be determined by the 2nd-level
syndrome and the block triviality obtained from a full
syndrome measurement. By knowing the block parity,
high-weight errors can be corrected using WPEC.
types of faults up to 3 faults, including any gate faults,
faults during the preparation and measurement of an-
cilla qubits, and faults during wait time. The circuit
construction in Fig. 1a, however, might not cause errors
that can be distinguished. Note that possible errors aris-
ing from CNOT faults heavily depend on the ordering of
CNOT gates being used in the measurement circuit. In
Section III, we will discuss conditions in which WPEC
can be applied. We will also provide a family of circuits
with specific CNOT ordering and an FTEC protocol for
the [[49, 1, 9]] code which can correct high-weight errors
arising from up to 3 faults.
III. FAULT-TOLERANT ERROR CORRECTION
PROTOCOL FOR THE [[49, 1, 9]] CODE
Fault-tolerant error correction is one of the most essen-
tial gadgets for constructing large-scale quantum com-
puters. Every FTEC protocol must satisfy the following
conditions:
Definition 2. Fault-tolerant error correction [5]
For t = b(d− 1)/2c, an error correction protocol using
a distance-d stabilizer code C is t-fault-tolerant if the
following two conditions are satisfied:
1. For any input codeword with error of weight v1, if
v2 faults occur during the protocol with v1 + v2 ≤
5t, ideally decoding the output state gives the same
codeword as ideally decoding the input state.
2. If v faults happen during the protocol with v ≤ t,
no matter how many errors are present in the in-
put state, the output state differs from any valid
codeword by an error of at most weight v.
In this work, we develop an FTEC protocol for the
[[49, 1, 9]] code that can correct up to 3 faults. The cir-
cuits for measuring 1st-level and 2nd-level generators are
shown in Fig. 2. The types of faults being considered
include faults that happen to the physical gates, faults
during the preparation and measurement of ancilla qubits
in the circuits, and faults during wait time.
(a)
(b)
FIGURE 2: Circuits for measuring 2nd-level and 1st-
level generators being used in this work are shown in
(a) and (b), respectively. With this gate permutation,
the block parity corresponding to every possible high-
weight error arising from up to 3 faults can be accurately
determined. As such, our protocol can correct up to 3
faults.
Let fault combination be a collection of faults up to
3 faults (which may be of different types and can cause
errors of weight much higher than 3 on the data qubits).
Our goal is to distinguish all fault combinations that can
be confusing and may cause WPEC to fail. Similar to
an example of WPEC in Section II, we can categorize all
possible fault combinations into subsets by their 2nd-level
syndrome and block triviality. The following sufficient
condition can determine when the WPEC technique can
be applied:
Claim 2. Sufficient condition for WPEC
Let F be the set of all possible fault combinations
during an FTEC protocol for the [[49, 1, 9]] code and let
Fk ⊆ F be a subset of fault combinations with the same
2nd-level syndrome and the same block triviality (where⋃
k Fk = F). WPEC is applicable in the FTEC protocol
if each Fk satisfies one of the following condition:
1. Data errors from all fault combinations in Fk give
equivalent block parities.
2. Not every data error from a fault combination in
Fk give the same block parity (or its equivalence),
but for each pair of fault combinations in Fk whose
block parities of their data errors are not equiva-
lent, their 1st-level syndromes or flag measurement
results (or both) are different.
Proof. Whenever subset Fk satisfies the first condition
in Claim 2, we can find a block parity that works for all
fault combinations in Fk using only the 2nd-level syn-
drome and the block triviality. A correction operator for
each fault combination can be found following the def-
inition of WPEC (Definition 1) using the 1st-level syn-
drome and the block parity. On the other hand, if Fk
satisfies the second condition in Claim 2, a block parity
cannot be accurately determined using only the 2nd-level
syndrome and the block triviality. Fortunately, with the
assistance of the 1st-level syndrome and the flag mea-
surement result, fault combinations that correspond to
non-equivalent block parities can be distinguished and
the block parity of each fault combination can be found.
Similarly, a correction operator for each fault combina-
tion can be determined following Definition 1.
Whether possible fault combinations satisfy Claim 2 or
not depends heavily on the ordering of the CNOT gates
and the use of flag qubits in the circuits for syndrome
measurements. In our FTEC protocol for the [[49, 1, 9]]
code, the CNOT gates being used in the circuits for mea-
suring 2nd-level generator are applied in the following
ordering:
(1, 8, 15, 22, 2, 9, 16, 23, . . . , 7, 14, 21, 28), (3)
where the numbers 1 to 28 represent the qubits in which
g˜zi acts nontrivially. That is, CNOT gates are applied on
the first qubit in each subblock for all subblocks, then on
the second qubit in each subblock for all subblocks, and
so on. The circuit for measuring g˜z1 is shown in Fig. 2a.
In addition, CNOT gates being used in the circuits for
measuring 1st-level generator are in the normal ordering
as shown in Fig. 2b. Note that there is no flag qubit
involved in the measurement of a 2nd-level generator,
and there is one flag qubit in the circuit for measuring a
1st-level generator.
Consider the case that there are some faults during Z-
type generator measurements. Faulty circuits can pro-
duce nontrivial flag measurement results and cause error
6of any weight on the data qubits. Our goal is to detect
and correct such error using the flag measurement re-
sults from the faulty circuits, together with 1st-level and
2nd-level syndromes obtained from subsequent syndrome
measurements. In particular, let the flag vector ∈ Z212 be
a bitstring wherein each bit is the flag measurement re-
sult from each circuit for measuring gzi on each of the 7
subblocks. We define the cumulative flag vector fx ∈ Z212
to be the entry-wise sum of flag vectors (modulo 2) ob-
tained from gzi measurements accumulated from the first
round up until the current round of measurements (see
the protocol described below for the definition of a round
of measurements). Cumulative flag vector fx together
with 1st-level syndrome sx ∈ Z212 , 2nd-level syndrome
s˜x ∈ Z32, and block triviality τx ∈ Z72 from the latest
round of measurements will be used for distinguishing
all possible fault combinations that can occur during the
syndrome measurements as described in Claim 2. Us-
ing the computer simulation described in Appendix A,
we can verify that Claim 2 is satisfied when the num-
ber of input errors v1 and the number of faults v2 satisfy
v1+v2 ≤ 3. A table of possible data errors and their cor-
responding sx, s˜x, τx, fx, and block parity px (similar to
Table I) can also be obtained from the simulation. More-
over, the subsets Fk can be deduced from this table (see
Appendix A for more details).
Let the outcome bundle be the collection of 1st-level
syndrome s = (sx|sz), 2nd-level syndrome s˜ = (s˜x|s˜z),
block triviality τ = (τx|τz), and cumulative flag vector
f = (fx|fz) obtained during a single round of full syn-
drome measurement, where subscripts x and z denote
results corresponding to X-type and Z-type generator
measurements. Using the simulation result together with
the fact that X-type and Z-type errors can be corrected
separately, an FTEC protocol for the [[49, 1, 9]] can be
constructed as follows.
FTEC protocol for the [[49, 1, 9]] code
A full syndrome measurement, or a round of measure-
ments, measure the generators in the following order:
measure all g˜zi ’s, then all g˜
x
i ’s, then all g
z
i ’s, then all g
x
i ’s.
Perform full syndrome measurements until the outcome
bundles are repeated 4 times in a row. Afterwards, per-
form the following error correction procedure:
1. Find the subset Fk corresponding to s˜x and τx from
the table of possible errors (obtained from the sim-
ulation in Appendix A).
(a) If Fk satisfies Condition 1 in Claim 2, use a
block parity of any fault combination in Fk.
(b) If Fk satisfies Condition 2 in Claim 2, use a
block parity of any combination in Fk that
corresponds to sx and fx.
(c) If there is no Fk from the table of possible
errors which corresponds to s˜x and τx, use the
block parity with all 1’s.
2. Let sx,i be the 1st-level syndrome and wi be the
weight parity of the i-th subblock. Apply Z-type
error correction on each subblock as given by Defi-
nition 1. In particular:
(a) If sx,i is trivial, apply ZZIZIII (logically
equivalent to Z⊗7) to the i-th subblock when
wi is odd, or do nothing when wi is even.
(b) If sx,i is nontrivial, apply E
z
wt-1(sx,i) to the
i-th subblock when wi is odd, or apply
Ezwt-2(sx,i) when wi is even.
3. If there is no Fk from the table of possible errors
which corresponds to s˜x and τx, further apply the
following error correction procedure: find a Pauli
operator from {ZIIIIII, IZIIIII, . . . , IIIIIIZ}
which corresponds to s˜x, then apply such operator
(or its logically equivalent operator) to the data
qubits.
4. Repeat steps 1–3 but use s˜z, sz, τz, and fz to
deduce the X-type error correction (Exwt-1(sz,i),
Exwt-2(sz,i), or XXIXIII) for each subblock.
Here we will assume that there are at most 3 faults dur-
ing the protocol and the error is of Z type. The assump-
tion on the number of faults guarantees that the outcome
bundles must be repeated 4 times in a row within 16
rounds (the outcome bundle cannot keep changing for-
ever since the number of faults is limited). To verify that
the protocol above is 3-fault-tolerant, i.e., it satisfies the
FTEC conditions in Definition 2 with t = 3 (the [[49, 1, 9]]
code acts as a distance-7 code), first let us consider the
case that there are no faults during the last round of full
syndrome measurement. In this case, the outcome bundle
corresponds to the actual data error. From the simula-
tion in Appendix A, we know that whenever v1 + v2 ≤ 3,
one of the conditions in Claim 2 is satisfied and the block
parity can be accurately determined. The operation in
Step 2 will give the correct output state, thus both of
the FTEC conditions are satisfied. On the other hand,
if v1 + v2 > 3 but v2 ≤ 3, s˜x and τx may not correspond
to any error in the table of possible errors. By using
the block parity with all 1’s, the operation in Step 2 will
project the state in each subblock back to the subspace
of the [[7, 1, 3]] code, where each subblock has an error
equivalent to either I or Z after the operation. After-
wards, the operation in Step 3 will project the output
state back to the subspace of the [[49, 1, 9]] code. Thus,
the second condition in Definition 2 is satisfied.
Now, let us consider the case that there are some faults
during the last round of full syndrome measurement. The
outcome bundle we obtained from the last round may
not correspond to the data error since some errors aris-
ing during the last round may be undetectable. Since we
perform full syndrome measurements until the outcome
bundles are repeated 4 times in a row and there are at
most 3 faults during the whole protocol, at least one of
the last 4 rounds of full syndrome measurement must be
correct. From the simulation result in Appendix A, the
outcome bundle obtained from the last round (which is
7equal to that obtained from any correct round in the last
4 rounds) can definitely correct the error occurred before
the last correct round. Here we want to verify that when-
ever the last 4 rounds have v faults (where v ≤ 3), after
the last round, the weight of the data error is increased
by no more than v. This can be verified using the com-
puter simulation described in Appendix B. By applying
operation in Step 2 (and possibly Step 3) as previously
discussed, the output state differs from a valid codeword
by an error of weight at most v, regardless of the number
of input errors. Thus, the second condition in Defini-
tion 2 is satisfied. Furthermore, whenever v1 + v2 ≤ 3,
we will obtain an output state which differs from a correct
output state by an error of weight at most 3. Therefore,
the first condition in Definition 2 is also satisfied.
The analysis for X-type errors is similar to that of
Z-type errors. Note that during the measurement of Z-
type generators, a single gate fault can cause an X-type
error of weight 1 on the data qubits. This error can be
considered as an input error for the measurement of X-
type generators, thus the same analysis is applicable.
IV. WEIGHT PARITY ERROR CORRECTION
FOR OTHER CODES
Besides the Steane code, we find that the WPEC tech-
nique is applicable to the [[23, 1, 7]] Golay code [6], which
is a perfect CSS code of distance 7. The [[23, 1, 7]] Golay
code can correct up to 3 errors and can be constructed
from the parity check matrix of the classical [23, 12, 7]
Golay code [33]. In cyclic form, the [[23, 1, 7]] Golay code
can be constructed from the parity check matrix,
1 1 1 1 1 0 0 1 0 0 1 0 1 0 0 0 0 0 0 0 0 0 0
0 1 1 1 1 1 0 0 1 0 0 1 0 1 0 0 0 0 0 0 0 0 0
0 0 1 1 1 1 1 0 0 1 0 0 1 0 1 0 0 0 0 0 0 0 0
0 0 0 1 1 1 1 1 0 0 1 0 0 1 0 1 0 0 0 0 0 0 0
0 0 0 0 1 1 1 1 1 0 0 1 0 0 1 0 1 0 0 0 0 0 0
0 0 0 0 0 1 1 1 1 1 0 0 1 0 0 1 0 1 0 0 0 0 0
0 0 0 0 0 0 1 1 1 1 1 0 0 1 0 0 1 0 1 0 0 0 0
0 0 0 0 0 0 0 1 1 1 1 1 0 0 1 0 0 1 0 1 0 0 0
0 0 0 0 0 0 0 0 1 1 1 1 1 0 0 1 0 0 1 0 1 0 0
0 0 0 0 0 0 0 0 0 1 1 1 1 1 0 0 1 0 0 1 0 1 0
0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 0 0 1 0 0 1 0 1

,
which can be generated from the check polynomial
h(x) = x12 + x10 + x7 + x4 + x3 + x2 + x + 1 [33]. The
i-th Z-type (or X-type) generator of this code will be
denoted as gzi (or g
x
i ) where i = 1, . . . , 11. The logical X
and logical Z operators of this code can be chosen to be
X¯ = X⊗23S and Z¯ = Z⊗23T for any stabilizer operators
S, T .
Similar to the [[7, 1, 3]] code, we can prove the equiv-
alence of errors with the same syndrome and the same
weight parity as follows:
Claim 3. Logical equivalence of errors with the same
syndrome for the [[23, 1, 7]] Golay code
Suppose E1, E2 are arbitrary Z-type errors (of any
weights) on the [[23, 1, 7]] code with the same syndrome.
Then, E1 and E2 have the same weight parity iff E1 =
E2S for some stabilizer S.
Proof. We can verify that every Z-type stabilizer in the
stabilizer group of the [[23, 1, 7]] code has even weight, and
every logical Z operator has odd weight. The rest of the
proof follows the proof of Claim 1.
Let us consider Z-type error correction for the [[23, 1, 7]]
code. Since the code is a perfect CSS code of distance 7,
for each sx ∈ Z112 , (sx|0...0) is the syndrome of a unique
Z-type error of weight ≤ 3. Suppose that a codeword is
corrupted by a Z-type error with syndrome sx. If we ap-
ply the minimal weight error correction corresponding to
sx, we sometimes obtain the codeword with undesirable
logical Z operator. Fortunately, by knowing the weight
parity of the error, the WPEC technique can be applied.
The error correction procedure for the [[23, 1, 7]] code is
defined as follows:
Definition 3. Weight parity error correction for the
[[23, 1, 7]] Golay code
Suppose a Z-type error E occurs to a codeword of the
[[23, 1, 7]] code. Let sx and w be the syndrome and the
weight of E, and let Ezmin(sx) be the unique minimal
weight error correction corresponding to the syndrome sx.
The following procedure is called weight parity error cor-
rection (WPEC):
1. If Ezmin(sx) has even weight (0 or 2), apply
Ezmin(sx) to the data qubits whenever w is even,
or apply any Z-type operator P that has odd weight
and corresponds to sx to the data qubits whenever
w is odd.
2. If Ezmin(sx) has odd weight (1 or 3), apply E
z
min(sx)
to the data qubits whenever w is odd, or apply any
Z-type operator P that has even weight and corre-
sponds to sx to the data qubits whenever w is even.
Note that the [[23, 1, 7]] Golay code can be made cyclic,
thus it can distinguish high-weight errors in consecutive
form [19]. Claim 3 together with the cyclic property give
us some possibilities to construct an FTEC protocol for
the [[529, 1, 49]] concatenated Golay code in the same way
as what we have done for the [[49, 1, 9]] code. We expect
that our technique can lead to a protocol which can cor-
rect a large number of faults and will compare well with
other FTEC schemes. To reach this goal, syndrome ex-
traction circuits with appropriate permutation of gates
(and possibly with flag qubits) must be found so that
conditions similar to those in Claim 2 are satisfied. The
search for such circuits with careful numerical verification
of fault-tolerance is a challenging and interesting future
research direction.
8The WPEC technique may also apply to the code ob-
tained from concatenating the Steane code to the k-th
level, e.g., the [[7k, 1, 3k]] code. Since the k-th level Steane
code is a distance-3 code, we expect that a block of errors
in the (k−1)-th level can be determined and corrected us-
ing the syndrome and the block parity defined at the k-th
level. Again, however, appropriate syndrome extraction
circuits must be found, which is beyond the scope of this
work.
V. DISCUSSIONS AND CONCLUSIONS
In this work, we prove the logical equivalence between
errors of any weight on 7 qubits which have the same
weight parity and correspond to the same error syn-
dromes when error detection is performed by the [[7, 1, 3]]
code in Claim 1. From this result, we introduce the
WPEC technique in Definition 1, which can correct errors
of any weight on 7 qubits whenever their weight parity
is known. We show that the WPEC technique can be
extended to error correction in subblocks of the [[49, 1, 9]]
code, and we prove the sufficient condition for WPEC
in Claim 2. Afterwards, we provide a family of circuits
and an FTEC protocol for the [[49, 1, 9]] code which can
correct up to 3 faults. We also point out that the WPEC
technique seems applicable to FTEC schemes for other
codes such as the concatenated Golay code and concate-
nated Steane code with more than 2 levels of concatena-
tion.
Since the FTEC protocol provided in this work satis-
fies the definition of FTEC in Definition 2 with t = 3, we
can guarantee that the logical error rate is suppressed to
O(p4) whenever the physical error rate is p under the ran-
dom Pauli noise model. Note that we did not use the full
ability of a code with distance 9 which, in principle, can
correct up to 4 errors. In terms of error suppression, our
FTEC protocol is as good as typical FTEC protocols for
a concatenated code which are constructed by replacing
each physical qubit with a code block and replacing each
physical gate with the corresponding logical gate [5].
One major advantage of our protocol is that only 2
ancillas are needed: one ancilla for a syndrome measure-
ment result and another ancilla for a flag measurement
result (assuming that the qubit preparation and mea-
surement are fast compared to the gate operation time).
As a result, our protocol requires 51 qubits in total.
The number of required qubits is very low compared to
other FTEC protocols for the [[49, 1, 9]] code; the FTEC
schemes in [15, 16] extended to the [[49, 1, 9]] code require
63 qubits in total (the minimum number of required an-
cillas are 14 assuming that they are recyclable). Mean-
while, the FTEC protocol in [30] which extracts multiple
syndromes at once encodes 2 logical qubits and requires
no ancilla, but need to work on two code blocks (i.e.,
the minimum number of required qubits are 98). We
believe that if the protocol requires fewer ancillas with-
out affecting the fault-tolerant properties, the number
of locations (and thus the number of fault combinations
that can cause the protocol to fail) in the error correction
gadget should decrease, which may improve the accuracy
threshold. However, a simulation with careful analysis is
required for the accuracy threshold calculation, thus we
leave this for future work.
The protocol in Section III which can correct up to 3
faults exploits two techniques; flag technique which parti-
tions set of possible errors using flag measurement results,
and WPEC technique which corrects errors of any weight
using their syndromes and weight parities. It should be
emphasized that flag ancillas are not necessarily required
for a protocol exploiting WPEC technique; we find that a
protocol which uses circuits similar to a circuit in Fig. 2a
for 2nd-level syndrome measurements and uses non-flag
circuits for 1st-level measurements can correct up to 2
faults.
We point out that the permutation of CNOT gates in
the syndrome extraction circuits that make the protocol
satisfies Claim 2 is not unique. We choose the permu-
tation in Eq. (3) by using the fact that a CSS code con-
structed from classical cyclic codes can distinguish high-
weight errors in the consecutive form [19]. In particular,
the circuit is designed in the way that high-weight errors
arising in each subblock can be determined by the under-
lying [[7, 1, 3]] code in cyclic form. We did not prove the
optimality of the choice of gate permutation our proto-
col, so an FTEC protocol for the [[49, 1, 9]] code with only
one ancilla or a protocol that can correct up to 4 faults
might be possible.
Last, we note that the WPEC technique introduced in
this work is not limited to the [[49, 1, 9]] code. In Sec-
tion IV, we prove the logical equivalence of errors with
the same syndrome and weight parity for the [[23, 1, 7]]
Golay code in Claim 3 and provide a WPEC scheme
in Definition 3, which shows that WPEC can correct
some high-weight errors in a subblock of the [[529, 1, 49]]
concatenated Golay code. In addition, we expect that
WPEC can be applied to any concatenated Steane code
with more than 2 levels of concatenation in a similar fash-
ion. However, circuits and a protocol must be carefully
designed so that the full error correction ability of the
code can be achieved. Another interesting future direc-
tion would be extending the WPEC technique to other
families of quantum codes.
VI. ACKNOWLEDGEMENTS
We thank Christopher Chamberland, Rui Chao,
Narayanan Rengaswamy, and Michael Vasmer for inter-
esting comments and suggestions. T.T. acknowledges
the support of The Queen Sirikit Scholarship under The
Royal Patronage of Her Majesty Queen Sirikit of Thai-
land. D.L. is supported by an NSERC Discovery grant.
Perimeter Institute is supported in part by the Govern-
ment of Canada and the Province of Ontario.
9[1] P. W. Shor, “Fault-tolerant quantum computation,” Pro-
ceedings., 37th Annual Symposium on Foundations of
Computer Science, pp. 56–65, 1996.
[2] D. Aharonov and M. Ben-Or, “Fault-tolerant quantum
computation with constant error rate,” SIAM Journal
on Computing, 2008.
[3] J. Preskill, “Reliable quantum computers,” Proceedings
of the Royal Society of London. Series A: Mathematical,
Physical and Engineering Sciences, vol. 454, no. 1969,
pp. 385–410, 1998.
[4] E. Knill, R. Laflamme, and W. H. Zurek, “Thresh-
old accuracy for quantum computation,” arXiv: quant-
ph/9610011, 1996.
[5] P. Aliferis, D. Gottesman, and J. Preskill, “Quantum
accuracy threshold for concatenated distance-3 codes,”
Quantum Info. Comput., vol. 6, no. 2, pp. 97–165, 2006.
[6] A. M. Steane, “Overhead and noise threshold of fault-
tolerant quantum error correction,” Physical Review A,
vol. 68, no. 4, p. 042322, 2003.
[7] A. Paetznick and B. W. Reichardt, “Fault-tolerant an-
cilla preparation and noise threshold lower boudds for the
23-qubit golay code,” Quantum Info. Comput., vol. 12,
pp. 1034–1080, Nov. 2012.
[8] C. Chamberland, T. Jochym-O’Connor, and
R. Laflamme, “Overhead analysis of universal con-
catenated quantum codes,” Phys. Rev. A, vol. 95,
p. 022313, Feb 2017.
[9] R. Takagi, T. J. Yoder, and I. L. Chuang, “Error rates
and resource overheads of encoded three-qubit gates,”
Phys. Rev. A, vol. 96, p. 042302, Oct 2017.
[10] D. P. DiVincenzo and P. Aliferis, “Effective fault-tolerant
quantum computation with slow measurements,” Phys.
Rev. Lett., vol. 98, p. 020501, Jan 2007.
[11] E. Knill, “Scalable quantum computing in the presence
of large detected-error rates,” Phys. Rev. A, vol. 71,
p. 042322, Apr 2005.
[12] A. M. Steane, “Active stabilization, quantum compu-
tation, and quantum state synthesis,” Phys. Rev. Lett.,
vol. 78, pp. 2252–2255, Mar 1997.
[13] A. M. Steane, “Fast fault-tolerant filtering of quantum
codewords,” arXiv preprint quant-ph/0202036, 2002.
[14] A. W. Steane, “Multiple-Particle Interference and Quan-
tum Error Correction,” Proc. Roy. Soc. Lond., vol. 452,
pp. 2551–2577, 1996.
[15] T. J. Yoder and I. H. Kim, “The surface code with a
twist,” Quantum, vol. 1, p. 2, Apr. 2017.
[16] R. Chao and B. W. Reichardt, “Quantum error cor-
rection with only two extra qubits,” Phys. Rev. Lett.,
vol. 121, p. 050502, Aug 2018.
[17] R. Chao and B. W. Reichardt, “Flag fault-tolerant er-
ror correction for any stabilizer code,” arXiv preprint
arXiv:1912.09549, 2019.
[18] C. Chamberland and M. E. Beverland, “Flag fault-
tolerant error correction with arbitrary distance codes,”
Quantum, vol. 2, p. 53, Feb. 2018.
[19] T. Tansuwannont, C. Chamberland, and D. Leung,
“Flag fault-tolerant error correction, measurement, and
quantum computation for cyclic calderbank-shor-steane
codes,” Physical Review A, vol. 101, no. 1, p. 012342,
2020.
[20] C. Chamberland, A. Kubica, T. Yoder, and G. Zhu, “Tri-
angular color codes on trivalent graphs with flag qubits,”
New Journal of Physics, 2020.
[21] C. Chamberland, G. Zhu, T. J. Yoder, J. B. Hertzberg,
and A. W. Cross, “Topological and subsystem codes on
low-degree graphs with flag qubits,” Physical Review X,
vol. 10, no. 1, p. 011022, 2020.
[22] R. Chao and B. W. Reichardt, “Fault-tolerant quantum
computation with few qubits,” npj Quantum Informa-
tion, vol. 4, no. 1, p. 42, 2018.
[23] C. Chamberland and A. W. Cross, “Fault-tolerant magic
state preparation with flag qubits,” Quantum, vol. 3,
p. 143, 2019.
[24] Y. Shi, C. Chamberland, and A. Cross, “Fault-tolerant
preparation of approximate gkp states,” New Journal of
Physics, vol. 21, no. 9, p. 093007, 2019.
[25] P. Baireuther, M. Caio, B. Criger, C. W. Beenakker,
and T. E. OBrien, “Neural network decoder for topo-
logical color codes with circuit level noise,” New Journal
of Physics, vol. 21, no. 1, p. 013003, 2019.
[26] A. Bermudez, X. Xu, M. Gutie´rrez, S. Benjamin,
and M. Mu¨ller, “Fault-tolerant protection of near-
term trapped-ion topological qubits under realistic noise
sources,” Physical Review A, vol. 100, no. 6, p. 062307,
2019.
[27] C. Vuillot, “Is error detection helpful on ibm 5q
chips?,” Quantum Information and Computation, vol. 18,
no. 11&12, pp. 0949–0964, 2018.
[28] M. Gutie´rrez, M. Mu¨ller, and A. Bermu´dez, “Transver-
sality and lattice surgery: Exploring realistic routes to-
ward coupled logical qubits with trapped-ion quantum
processors,” Physical Review A, vol. 99, no. 2, p. 022330,
2019.
[29] L. Lao and C. G. Almudever, “Fault-tolerant quantum
error correction on near-term quantum processors us-
ing flag and bridge qubits,” Physical Review A, vol. 101,
no. 3, p. 032333, 2020.
[30] B. W. Reichardt, “Fault-tolerant quantum error correc-
tion for steane’s seven-qubit color code with few or no
extra qubits,” arXiv preprint arXiv:1804.06995, 2018.
[31] A. R. Calderbank and P. W. Shor, “Good quantum error-
correcting codes exist,” Phys. Rev. A, vol. 54, pp. 1098–
1105, Aug 1996.
[32] D. Gottesman, Stabilizer Codes and Quantum Error Cor-
rection. PhD thesis, California Institute of Technology,
1997.
[33] F. J. MacWilliams and N. J. A. Sloane, The theory of
error-correcting codes. North-Holland, New York, 1977.
10
Appendix A: Simulation of possible faults during the
FTEC protocol assuming that the last round of full
syndrome measurement has no faults
As discussed in Section III, in order to verify that the
FTEC protocol for the [[49, 1, 9]] code satisfies the FTEC
conditions in Definition 2, we consider two separate cases:
the case that there are some faults during the last round
of full syndrome measurement, and the case that there
are not. In this section, we provide details of a simulation
to show that whenever the number of faults is at most
3 and none of the faults occurs during the last round,
all possible fault combinations satisfy Claim 2 and our
protocol can correct errors on the data qubits.
In our protocol, we will perform full syndrome mea-
surements until the outcome bundles are repeated 4 times
in a row. Since there are at most 3 faults, the repeti-
tion condition will be satisfied within 16 rounds of full
syndrome measurement. In this simulation, we assume
that the last round of measurement has no faults, thus
the high-weight error on the data qubits arising from at
most 3 faults is accumulated from up to 15 rounds. We
will use the outcome bundle (syndromes and flag vector)
obtained from the last round to determine the fault com-
bination that cause the error so that the corresponding
weight parity can be found and the WPEC can be done.
We first define mathematical objects being used in our
simulation. Let fault be an object with two associated
variables: Pauli error defined on the code block of 49
qubits arising from the fault, and flag vector ∈ Z212 which
indicates the flag measurement results associated with
the fault. There are 4 types of possible faults: faults
during wait time (denoted by W ), faults arising from the
measurement of 1st-level and 2nd-level generators (de-
noted by G1 and G2, respectively), and flag measurement
faults (denoted by F ). A fault combination can be con-
structed by combining faults of same or different types
up to 3 faults, i.e., multiplying their Pauli errors and
adding their flag vectors. The errors on the input code-
word can be considered as wait time faults in which asso-
ciated Pauli errors do not propagate to other data qubits
during the FTEC protocol. In addition, the X-type er-
rors on the data qubits arising from the faults during the
measurement of Z-type generators can be considered as
wait time faults during the measurement of subsequent
X-type generators, in which our simulation is also ap-
plicable. (Since the last round of measurement has no
faults, we can assume that the syndromes obtained from
the last round are correct and the syndrome measure-
ment faults can be neglected.)
Next, we define fault set as follows: for faults of type
G1 (or type G2), we denote F
G1
i,j (or F
G2
i,j′) to be sets
of possible G1 (or G2) faults arising from a circuit for
measuring gzj , j = 1, . . . , 21 (or g˜
z
j′ , j
′ = 1, 2, 3) where
the number of faults is i ∈ {0, 1, 2, 3} (gzj refers to the
generator gz(j−1) mod 3+1 on the dj/3e-th subblock). Also,
we denote FWi and F
F
i to be sets of possible faults of type
W and F , respectively, where the number of faults is i ∈
{0, 1, 2, 3}. In addition, we define fault set combination
to be a set of fault sets up to 3 sets.
Last, let vG1 , vG2 , vW , vF be the number of faults of
type G1, G2,W, and F , respectively. (vG1 , vG2 , vW , vF )
that satisfies vG1 + vG2 + vW + vF ≤ 3 is called fault
number combination.
With the definitions of fault, fault combination, fault
set, fault set combination, and fault number combination,
now we are ready to describe the simulation.
Pseudocode for a simulation of possible faults
assuming that the last round of full syndrome
measurement has no faults
1. Construct fault sets FG1i,j , F
G2
i,j′ , F
W
i , and F
F
i for all
i = 0, 1, 2, 3, j = 1, . . . , 21, j′ = 1, 2, 3.
2. Construct all possible fault number combinations
that satisfy vG1 + vG2 + vW + vF ≤ 3.
3. For each (vG1 , vG2 , vW , vF ), find all possible fault
set combinations from vG1 , vG2 , vW , vF . Note that
if vG1 is 2, the fault set combination can have F
G1
i,j
and FG1i′,j′ with i = i
′ = 1, or have FG1i,j with i = 2.
Also, if vG1 is 3, the fault set combination can have
FG1i,j , F
G1
i′,j′ , and F
G1
i′′,j′′ with i = i
′ = i′′ = 1, or have
FG1i,j and F
G1
i′,j′ with i = 2, i
′ = 1, or have FG1i,j with
i = 3. The same goes for vG2 .
(a) For each fault set combination, find all possi-
ble fault combinations. Each fault combina-
tion can be found by picking one fault from
each fault set (up to 3 sets) in the fault set
combination, then combine the faults to get
the Pauli error E and the cumulative flag vec-
tor fx associated with the fault combination.
(b) For each fault combination, find 1st-level syn-
drome sx, 2nd-level syndrome s˜x, block triv-
iality τx, and block parity px from the asso-
ciated Pauli error E. Store (sx, s˜x, τx, fx, px)
for each fault combination in a lookup table.
4. After the lookup table is complete, categorize fault
combinations by their 2nd-level syndromes and
block trivialities in order to get Fk’s as in Claim 2.
5. For each Fk, verify whether Condition 1 or 2 in
Claim 2 is satisfied.
From the simulation above, we find that all possible
fault combinations satisfy Claim 2. That is, for each
fault combination, we can determine the weight parity
from the outcome bundles obtained from the last round
of full syndrome measurement by looking at the table
constructed in Step 3b. The weight parity can be later
used to perform WPEC on the code block. With this
simulation result, we can verify our FTEC protocol for
the [[49, 1, 9]] satisfies FTEC conditions as previously dis-
cussed in Section III.
11
Appendix B: Simulation of possible faults during the
FTEC protocol assuming that the last round of full
syndrome measurement has some faults
In Appendix A, we describe the simulation of possible
faults during the FTEC protocol for the [[49, 1, 9]] code
which is applicable to the case that there are no faults
during the last round of full syndrome measurement. In
this section, we will extend the ideas and construct a
simulation of possible faults for the case that some faults
occur during the last round.
As previously described, we will perform full syndrome
measurements in the protocol until the outcome bundles
are repeated 4 times in a row. Now, suppose that the last
round of full syndrome measurement has some faults. In
this case, we cannot be sure whether the outcome bundle
from the last round exactly corresponds to the error in
the data qubits. Fortunately, since there are at most 3
faults during the whole protocol, at least one outcome
bundle obtained from the last 4 rounds must be correct.
Note that the outcome bundles from the last 4 rounds
are identical. From the simulation result discussed in
Appendix A, the outcome bundle from the last round
can be used to correct the data error occurred before any
correct round using the WPEC technique (see Fig. 3 for
more details). The goal of the simulation in this section is
to verify that all possible fault combinations which can
happen after the last correct round give data error of
weight no more than 3.
FIGURE 3: At least one of the last 4 rounds of full syn-
drome measurement is correct since there are at most
3 faults. Because the outcome bundles from the last 4
rounds are identical, the outcome bundle from the last
round can be used in WPEC to correct both errors E1
and E2 (even though E1 and E2 may not be equal).
A straightforward way to verify the claim above is to
find all possible fault combinations and check the weight
of their associated Pauli errors. Unfortunately, this pro-
cess requires a lot of computational resources. Thus, we
will use “relaxed conditions” for the verification instead;
for each fault combination, if the associated Pauli error
and flag vector satisfy all relaxed conditions, the fault
combination will be marked (indicating that the fault
combination might cause the protocol to fail). We want
to make sure that for all fault combination that can cause
the protocol to fail (i.e., its associated error has weight
more than 3), the fault combination will be marked. Note
that some fault combinations may be marked by the re-
laxed conditions but will not cause the protocol to fail.
For this reason, all of the marked fault combinations must
be examined after the simulation is done.
We should note that the order of generator measure-
ments is important for the fault tolerance of our FTEC
protocol. Consider the protocol description in Section III
in which we measure generator measurements in the fol-
lowing order during a single round of full syndrome mea-
surement: measuring all g˜zi ’s, then all g˜
x
i ’s, then all g
z
i ’s,
then all gxi ’s. Let us first consider the errors that can be
caught by the gxi measurements of the last round. Ob-
serve that all Z-type data errors that arise before the
gxi measurements of the last round will be evaluated by
the 1st-level syndrome sx. However, some faults during
gxi measurements of the last round may cause X-type or
Z-type errors that will not be caught by any syndrome.
Without loss of generality, we will construct a simulation
using an assumption that faults before the gxi measure-
ments of the last round can cause only Z-type errors, and
faults during or after the gxi measurements can cause X-
type or Z-type errors. The simulation is also applicable
to the case of gzi measurements.
Let E, E˜a, and E˜b be data errors arising from faults
occurred before the last correct round among the last 4
rounds, faults occurred after the last correct round but
before the gxi measurements of the last round, and faults
occurred during or after the gxi measurements of the last
round. The errors can be illustrated as follows:
The outcome bundle obtained from the last round is
equal to the outcome bundle obtained from the correct
round and can be used to correct E. Thus, we would like
to mark every fault combination that can occur after the
correct round, corresponds to the trivial outcome bundle
(since the outcome bundle obtained from the last round
is the same as that obtained from the correct round), and
corresponds to a Pauli error of weight more than 3. In
particular, our relaxed conditions will examine 3 objects
for each fault combination: the 1st-level syndrome, the
cumulative flag vector, and the weight of the Pauli error.
The mathematical objects being used in this simula-
tion are similar to those defined in Appendix A. In ad-
dition, we will consider syndrome measurement faults
(denoted by S) as another type of faults in this simu-
lation since we will assume that the syndrome measure-
ment during the last 4 rounds can be faulty. Also, let
vG1a be the number of G1 faults that occur before the
gxi measurements of the last round, and let vG1b be the
number of G1 faults that occur during or after the g
x
i
measurements of the last round. Fault number combina-
tion is a tuple (vG1a , vG1b , vG2 , vW , vF , vS) that satisfies
vG1a + vG1b + vG2 + vW + vF + vS ≤ 3.
For the first relaxed condition, let us first assume
that none of the faults of type W occurs before or dur-
ing the gxi measurements of the last round. For each
12
(vG1a , vG1b , vG2 , vW , vF , vS), error E˜a will be constructed
from possible fault combinations that correspond to vG1a
and vG2 . We will mark every fault combination whose as-
sociated E˜a gives a 1st-level syndrome that has Hamming
weight no more than vS (where the Hamming weight is
the number of 1’s in a bitstring). This is because each
fault of type S can alter at most 1 syndrome bit. Now let
us consider the case that some faults of type W occurs
before or during the gxi measurements. Each W fault
(which corresponds to error of weight 1) can change at
most 3 bits of sx, but the change will affect only the sub-
block in which the fault acts nontrivially. We will define
function σ(E˜a, vW ) by the following calculation:
1. Find the 1st-level syndrome of E˜a and calculate
the Hamming weight of the syndrome for each sub-
block.
2. Sort the Hamming weights from all subblocks. The
function value is the the sum of the 7−vW smallest
Hamming weights.
The value of σ(E˜a, vW ) is the minimum Hamming weight
of the 1st-level syndrome when vW faults of type W oc-
cur. Taking all fault types into account, our first relaxed
condition becomes
σ(E˜a, vW ) ≤ vS . (B1)
For the second relaxed condition, we will consider the
cumulative flag vector associated with each fault combi-
nation. Note that a flag measurement result will be ob-
tained during any gxi or g
z
i measurement. Let f = (fx|fz)
denote the cumulative flag vector associated with each
fault combination, and let h(f) denote the Hamming
weight of f . Since each fault of type F can alter at most
1 bit of f , our second relaxed condition becomes,
h(f) ≤ vF . (B2)
For the third relaxed condition, we will consider the
weight of the Pauli error associated with each fault com-
bination. The weight is evaluated at the end of the pro-
tocol where the resulting error is caused by all faults of
type G1, G2, and W (errors arising during or after the
gxi measurements of the last round can be X-type or Z-
type). If W faults do not occur before or during the gxi
measurements at the last round, the weight of the result-
ing error is the weight of E˜a · E˜b. If they do, each W
fault can increase the total weight by at most 1. Hence,
our third condition becomes,
wt(E˜a · E˜b) + vW > 3. (B3)
Note that the weight of E˜a·E˜b can be reduced by multipli-
cation of some stabilizer, and the fault combination will
not be marked unless Eq. (B3) is satisfied for all choice
of stabilizer.
Using the relaxed conditions in Eqs. (B1) to (B3), our
simulation to verify that all possible data errors arising
after the correct round have weight no more than 3 can
be constructed as follows:
Pseudocode for a simulation of possible faults
assuming that the last round of full syndrome
measurement has some faults
1. Construct fault sets FG1i,j , F
G2
i,j′ for all i = 0, 1, 2, 3,
j = 1, . . . , 21, j′ = 1, 2, 3.
2. Construct all possible fault number combinations
that satisfies vG1a +vG1b +vG2 +vW +vF +vS ≤ 3.
3. For each (vG1a , vG1b , vG2 , vW , vF , vS), construct all
possible fault set combinations from only vG1a ,
vG1b , and vG2 . During the construction of each
fault set combination, label fault sets that come
from vG1a or vG2 with letter a, and label fault sets
that come from vG1b with letter b. Note that if
vG1a is 2, the fault set combination can have F
G1
i,j
and FG1i′,j′ with i = i
′ = 1, or have FG1i,j with i = 2.
Also, if vG1a is 3, the fault set combination can have
FG1i,j , F
G1
i′,j′ , and F
G1
i′′,j′′ with i = i
′ = i′′ = 1, or have
FG1i,j and F
G1
i′,j′ with i = 2, i
′ = 1, or have FG1i,j with
i = 3. The same goes for vG1b and vG2 .
(a) For each fault set combination, find all possi-
ble fault combinations. Each fault combina-
tion can be found by picking one fault from
each fault set (up to 3 sets) in the fault set
combination. E˜a associated with each fault
combination can be found by combining only
faults from fault sets with label a, while f and
E˜a · E˜b can be found by combining faults from
all fault sets.
i. For each fault combination, if Eqs. (B1)
to (B3) are all satisfied, the fault com-
bination will be marked. Note that for
Eq. (B3), the weight of E˜a · E˜b must be
minimized by stabilizer multiplication.
From the simulation above, we find that there are 6
fault combinations which are marked by the relaxed con-
ditions in Eqs. (B1) to (B3). All of them corresponds to
the case that vG2 = 1, vW = 2, vG1a , vG1b , vF , vS = 0,
and their associated Pauli errors are trivial on 5 sub-
blocks and have either IIIIIIZ or ZIIIIII on 2 sub-
blocks. We find that IIIIIIZ and ZIIIIII correspond
to 1st-level syndrome (001) and (100), respectively. Since
vS = 0, the associated 1st-level syndrome must be trivial
whenever errors from W faults are taken into account.
This can only happen when errors from W faults can-
cel with the aforementioned Pauli error, which means
that the resulting error has weight 0. As a result, we
find that all of the marked fault combinations cannot
cause data error of weight higher than 3. Similar simula-
tions can be done to show that whenever v faults occur
where v = 0, 1, 2, the weight of the output error is at
most v. This result verifies that the FTEC protocol for
the [[49, 1, 9]] code satisfies FTEC conditions as previously
discussed in Section III.
