Real-time decoding of stabilizer measurements in a bit-flip code by Ristè, Diego et al.
Real-time decoding of stabilizer measurements in a bit-flip code
Diego Riste`,1, ∗ Luke C. G. Govia,1 Brian Donovan,1, † Spencer D. Fallek,1
William D. Kalfus,1 Markus Brink,2 Nicholas T. Bronn,2 and Thomas A. Ohki1
1Raytheon BBN Technologies, Cambridge, MA, USA
2IBM T. J. Watson Research Center, Yorktown Heights, NY, USA
(Dated: November 28, 2019)
Although qubit coherence times and gate fidelities are continuously improving, logical encoding is
essential to achieve fault tolerance in quantum computing. In most encoding schemes, correcting or
tracking errors throughout the computation is necessary to implement a universal gate set without
adding significant delays in the processor. Here we realize a classical control architecture for the fast
extraction of errors based on multiple cycles of stabilizer measurements and subsequent correction.
We demonstrate its application on a minimal bit-flip code with five transmon qubits, showing that
real-time decoding and correction based on multiple stabilizers is superior in both speed and fidelity
to repeated correction based on individual cycles. Furthermore, the encoded qubit can be rapidly
measured, thus enabling conditional operations that rely on feed-forward, such as logical gates. This
co-processing of classical and quantum information will be crucial in running a logical circuit at its
full speed to outpace error accumulation.
I. INTRODUCTION
Fault-tolerant quantum computation offers the poten-
tial for vast computational advantages over classical com-
puting for a variety of problems [1]. The implementation
of quantum error correction (QEC) is the first step to-
wards practical realization of any of these applications.
This typically requires detecting the occurrence of an
error by performing a stabilizer measurement, followed by
either a corrective action on the physical device (active
QEC), or a frame-update in software (passive QEC) [2–4].
In either case, these checkpoints must occur regularly
to protect a quantum state throughout the computation.
To do that, one needs to rapidly measure the stabilizers
with high fidelity and without disrupting the encoded
qubit. In spite of these challenges, recent progress has
been made in repetitive stabilizer measurements across a
diverse range of physical architectures including trapped
ions [5, 6], superconducting qubits [7–11], and defects in
diamond [12].
Active feed-forward control is useful not only for active
error correction [13–16], but also for other QEC schemes
employing state injection and magic-state distillation [3,
17], both of which may be used in implementations of a
universal logical gate set. In all cases, determining the
appropriate control and implementing it in real time with
minimal latency is a particularly attractive capability for
efficient error correction techniques [4].
Furthermore, when the stabilizer measurements cannot
be trusted as they themselves are error-prone, one can
introduce a decoder that uses information from multiple
rounds of stabilizer measurements [18] or from the spatial
connectivity of the device [19] to determine the appropri-
ate correction. Unfortunately, performing the decoding
∗ diego.riste@raytheon.com
† Current affiliation: Systems & Technology Research, Woburn,
MA, USA
calculation in software at a high level of the hardware
stack hinders low-latency correction and fast feed-forward
control due to the communication and computation over-
head [7].
In this Letter, we overcome this bottleneck by perform-
ing both QEC decoding and control with custom low-
latency hardware, which acts as a classical co-processor to
our quantum processor. We demonstrate repeated active
correction as well as real-time decoding of multi-round
stabilizer measurements. We show that the decoding
strategy successfully mitigates stabilizer errors and identi-
fies the encoded state with a latency far below the qubit
coherence times, while matching the results obtained by
post-processing on a conventional computer.
II. SETUP
For our demonstration, we implement a three-qubit
code that corrects bit-flip errors (Xˆ), and is sufficient to
encode one logical bit of classical memory. We use an IBM
five-transmon device similar to ibmqx2 [20, 21] (Fig. 1),
of which three transmons (D1, D2, D3) are used as data
qubits, and two (At, Ab) as ancilla qubits to measure
the stabilizers. Each qubit is coupled to a dedicated
resonator for readout and control. Additional resonators
dispersively couple D1, D2 with At and D2, D3 with Ab.
We perform CNOT gates between data and ancilla
qubits by using a sequence of single-qubit gates and
a ZX90 rotation driven by the cross-resonance interac-
tion [24]. By applying two CNOT gates in succession con-
trolled by two different data qubits with a single ancilla
as the target, the parity of the data qubit pair is mapped
onto the ancilla state. The same protocol is applied simul-
taneously to both data qubit pairs, with the shared qubit
D2 interacting first with At, then with Ab (Fig. 1b). The
ancilla measurement result at,b = 0(1) ideally corresponds
to even (odd) parity for the corresponding pair. We refer
to the complete sequence comprised of 4 CNOT gates
ar
X
iv
:1
91
1.
12
28
0v
1 
 [q
ua
nt-
ph
]  
27
 N
ov
 20
19
2D
1
A
t
D
2
A
b
D
3
readout
resonators
Purcell 
filter
JPA
JPC
(a)
(c)
(b)
a
t
 = e/o
D
2
D
1
A
t
D
3
A
b ab = e/o
ADC
qubit state assignment
DAC
Pulse Sequencers
FPGA
Conditional gates
0
1
From quantum
processor
To quantum
processor
if
 
0
if 1
t
X
ADC
FPGA Block RAM
Processor
 at ab  d1 d2 d3
0  0  -   -   -
1  0  -   -  - 
... 
Receivers
Meas. values 
Engine
result0
1
Acquire qubit measurements for processor engine
N cycles 
 
DAC
Pulse Sequencers
FPGA
FPGA DAC
To quantum
processor
f ({a, d}
1...N
)
FPGA DAC
Engine
1
2
3
n
e.g.
concurrent
FIG. 1. Stabilizer measurements on a five-transmon device. (a) Schematics of the device implementing the bit-flip code with
the data qubits D1, D2, D3 and the ancilla qubits At, Ab. Triangles represent the bus resonators coupling the qubits at their
vertices. A Josephson Parametric Amplifier [22] (Converter [23]) enhances the readout of At (Ab). (b) Gate and measurement
sequence for one round of stabilizer measurements. CNOT gates map the parity of D1 - D2 (D2 - D3) onto At (Ab) and are
applied concurrently two at a time. (c) Simplified setup diagram highlighting the closed loop central to active error correction
and decoding. For QEC cycles n ≤ N , the Processor stores the stabilizer results {at, ab}n acquired by the Receivers. When
n = N , it executes a custom function (here Decoder) and broadcasts the result back to the Pulse Sequencers for conditional
gates (here Xˆ). The same framework is used to execute a logical data measurement, where the Majority function is applied on a
single acquisition {d1, d2, d3}. Further detail is provided in Sec. II.
and ancilla measurement as a single error correction cycle.
The result of each cycle (the measurements at, ab) is a
syndrome which identifies which data qubit (if any) has
most likely been subjected to an Xˆ error.
Key to preserving a logical state is the capability of re-
peating such stabilizer measurements [6, 7, 10, 11], which
has two technical requirements. First, the two ancilla
qubits must be reused at every cycle, either by resetting
them to the ground state [25, 26] or by tracking their
state. For either reset or state-tracking by measurement,
we need to ensure that the readout process is nondestruc-
tive, i.e., the result is consistent with the qubit state at
the end of the measurement. This sets an upper limit
to the allowable photon number, and therefore to the
readout fidelity [27]. Second, the readout cavities must
be depleted of photons before starting the new cycle to
prevent gate errors. To accelerate the cavity relaxation
to its steady-state (near vacuum), we employ the CLEAR
technique [28] for the slower resonator coupled to Ab (Ta-
ble S2), reducing its average photon population to < 0.1
in 600 ns. Altogether, we measure a single-round joint
stabilizer readout fidelity of 0.61, averaged over the 8 com-
putational states of the data qubits (see Supplemental
Material Fig. S2).
An integral part of our experiment is the interdepen-
dence of qubit readout and control, mediated by fast
processing of the measurement results. For this purpose,
we use a combination of custom-made and off-the-shelf
hardware consisting of Pulse Sequencers, Receivers, and
a Processor (see Fig. 1c), all based on field-programmable
gate arrays (FPGAs). In particular, the storage capa-
bility of the Processor FPGA enables expansion beyond
one-time feedback protocols [8, 29, 30], where conditional
actions rely on single, or joint but simultaneous mea-
surements. During each QEC cycle, digital-to-analog
converters (DACs) in the Pulse Sequencers produce a
pre-programmed series of gate and measurement pulse
envelopes. Each returning readout signal is captured
by a Receiver channel via an analog-to-digital converter
(ADC), where it is integrated and compared against a
calibrated threshold to determine the qubit state [27, 29].
The Processor collects all the digitized results and stores
them in memory. After a preset number N of cycles have
been executed, the Processor feeds the stored values to
an internal custom calculation engine. The engine func-
tion result is broadcast to the Pulse Sequencers, which
conditionally apply a corresponding set of gates. The
overall latency to store and process the classical data and
to issue a conditional pulse is 590 ns, a small fraction of
coherence times [27].
We will explore three distinct approaches to the bit-flip
code. In all cases, we first prepare the logical excited
3state |111〉. Next, we apply one of the following schemes:
i) uncorrected, in which the cycle is performed but no
correction is applied to the data qubits based on the
syndrome measurements, and the ancilla qubits are not
reset; ii) repeated error correction (REC), in which a cor-
rection gate is conditionally applied to the data qubits
after each error correction cycle based on the syndrome
result, and the ancillas are reset; iii) decoder error cor-
rection (DEC), in which N cycles are performed without
ancilla reset or corrective gates and the set of syndromes
from all N cycles are used to determine and apply the
optimal correction via a decoder [18]. To assess how well
each code has protected the prepared state after a desired
number of cycles, we perform a logical data measurement.
This involves measuring the constituent physical data
qubits and computing the majority function over the dig-
itized results {d1, d2, d3}. In cases i) and ii), the majority
function is calculated offline. In case iii), the Processor
computes both the decoding and majority functions se-
quentially [27], making the result available for further
conditional operations.
III. RESULTS
We begin by comparing the REC protocol to the un-
corrected case (Fig. 2). For REC, there is a one-to-one
relation between the two-bit value syndrome {at, ab} and
one of the 3 possible corrective Xˆ gates (in blue in Fig. 2a),
or no gate at all. The same syndrome value is used to ac-
tively reset the ancilla qubits for use in subsequent cycles
(Fig. 2b).
When the correction is based on a single round of stabi-
lizer measurements, false positives (largely due to CNOT
gate and ancilla readout errors) immediately propagate
to the data qubits. These errors dominate in the case
of d1 and d3, whose average values decay faster with the
number of cycles than without active correction (Fig. 2b).
Conversely, the larger intrinsic error per cycle for d2 (due
to its shorter T1) is partially compensated by the pro-
tocol. Overall, this gain nearly balances out the errors
introduced by the active error correction, as shown by
comparing the results of the majority function (Fig. 2b).
REC can be thought of as repeated one-time feedback,
where the Processor storage and calculation engine are
unused. The added latency is considerable: for each cycle,
the stabilizer results are aggregated by the Processor and
forwarded to the Pulse Sequencers (400 ns), followed by
correction and reset operations (160 ns).
Improvements in logical state protection are achieved
by correlating multiple stabilizer measurements using the
DEC protocol. In Ref. [7], a simplified minimum-weight
perfect matching decoder [18] was used to post-process
the syndrome results and differentiate between true data
bit flips and false positives. We apply the same method
(Fig. 3), but with the crucial difference that the results
are processed in real time. Specifically, the Processor
acquires stabilizer measurement results for N cycles and
       
 1 X P E H U  R I  F \ F O H V N
   
   
   
   
   
   
 $ Y
 H U
 D J
 H 
 U H
 V X
 O W
       
 1 X P E H U  R I  F \ F O H V N
(a)
D
2
D
1
A
t
D
3
A
b
X
X
X
X
OR
OR
Correct
Verify
X
Reset
depletion
depletion
(b) (c)
|1ñ
|1ñ
|1ñ
|0ñ
|0ñ
m, REC
m, uncorr.RECuncorr.
N cycles
Majority
d
1
d
2
d
3
m
FIG. 2. Real-time repeated error correction with ancilla reset
(REC). (a) Gate sequence for independent cycles of active
error correction. (b) Average digitized result for each of D1
(red), D2 (blue), and D3 (green) measurements after initializa-
tion in |111〉 and N cycles of (a) (full symbols). The results
are compared to those obtained with the same circuit, but
where data correct and ancilla reset operations are omitted
(empty symbols). (c) Average majority vote m for the data in
(b). The closed-loop circuit (full symbols) does not improve
over open-loop (empty). In both (b-c), solid (dashed) curves
are obtained from the model for the corrected (uncorrected)
case [27]. Error bars correspond to the range over 5 repetitions
of the experiment, consisting of 3000 shots each.
uses the engine to decode them into the appropriate set
of Xˆ gates using a precomputed lookup table. These
corrections are then applied by the Pulse Sequencers on
the data qubits. Finally, the data qubits are measured as
in Fig. 2, with the majority function also computed on the
Processor. Whereas for N ≤ 2 the decoder is ineffective –
as there are not enough records to identify ancilla readout
errors – a gap emerges at larger N (Fig. 3c) in favor of
the decoder. Furthermore, this scheme eliminates the
per-cycle latency cost; the latest ancilla results can be
processed while the next cycle is executing. The total
additional latency becomes fixed at 1300 ns (590 ns for
each Processor engine call, 120 ns for corrective gates),
approximately equal to that accrued over 2 REC cycles
(Table I).
In an effort to minimize errors by avoiding unneces-
sary quantum gates, it is important to move as many
operations as possible to the classical hardware. In this
case, we note that measuring the data qubits immedi-
ately after conditional Xˆ gates is equivalent to inverting
the classical measurement result. Therefore, in a final
experiment (Fig. 4, triangles) we dispense with the active
correction and instead filter the di results based on the
4(b) (c)
(a)
D
2
D
1
A
t
D
3
A
b
X
X
X
AND/
OR
AND/
OR
Majority
d
1
d
2
d
3
|1ñ
|1ñ
|1ñ
|0ñ
|0ñ
DEC
m, DEC
m, uncorr.uncorr.
N cycles
Decode
a
t,n
a
b,n
a
t,1...N
a
b,1...N
m
FIG. 3. Real-time decoder-based error correction (DEC) and
logical measurement. (a) Gate sequence with active correction,
based on N rounds of stabilized measurements, followed by
simultaneous data qubit measurements and majority function.
The sequence in each cycle is identical to the uncorrected case
in Fig. 2 (including the cavity depletion, not shown). The
shaded areas highlight the real-time processing. (b) Average
results d1, d2, d3 following the conditional Xˆ gates in (a) (solid
symbols), compared to the uncorrected case (same as Fig. 2b)
(empty). Model curves for real-time correction are dash-dotted.
(c) Average majority vote m for the data in (b).
       
 1 X P E H U  R I  F \ F O H V N
   
   
   
   
   
   
 $ Y
 H U
 D J
 H 
 P
 D M
 R U
 L W \
free decay
       
    
    
    
    
    
⟨m
⟩ D
E⟩
−
⟨m
⟩ R
E⟩
REC
DEC
DEC+PFU
offline PFU
FIG. 4. Comparison between different QEC schemes. Mea-
sured average majority result m for REC (circles, from Fig. 2)
and DEC with final active correction (squares, Fig. 3). The
results obtained by replacing the correction in DEC with a
PFU (triangles) match those obtained by post-processing (di-
amonds) the uncorrected data using the same decoder. In all
DEC cases and for N > 1, m stays above the result expected
from an equivalent idle time (gray curve). Inset: difference
between the average majority result for DEC with PFU and
REC.
Protocol Latency/cycle (ns) Fixed latency (ns)
REC 560 > 1e6
DEC 0 1300
DEC + PFU 0 1180
TABLE I. Additional latency compared to the uncorrected
protocol. The latency includes the time for classical processing,
as well as active correction, where applicable.
decoder output. This corresponds to a Pauli-frame up-
date (PFU) [2] applied just before the measurement. The
slight reduction in latency (120 ns) and error rate due to
the absence of these pulses consistently achieves 1− 2%
improvement for all N over the actively corrected case.
The results match those obtained by post-processing all
the data in software (diamonds), confirming that the fast
classical loop works as expected.
Finally, we evaluate the decoder against the majority
result we would obtain by replacing the QEC gates and
measurements with an idle time of equal duration. The
result shows that, for all N > 1, DEC has a higher success
probability of determining the initial state compared to
free decay (Fig. 4, gray curve).
IV. CONCLUSIONS
Although the experiment ends with the measurement
of the data qubits, the readily available majority result
may be used to condition additional operations on a
second encoded qubit, such as for teleportation of a S
gate [31]. More generally, the ability to update the Pauli
frame in real time will be essential to implement quantum
algorithms at the logical level. Since not all gates can be
transversal in any given code [32], conditional operations
based on the current frame can be used to complete the
universal gate set (e.g. T gates in the surface code [17].)
In conclusion, we have demonstrated the repeated mea-
surement and real-time processing of stabilizers for a
minimal bit-flip code. An intertwined readout and con-
trol system provides a real-time interface to the quantum
processor, converting a series of stabilizer results to the
current Pauli frame without interrupting the execution
of a potential algorithm. This approach is not limited to
superconducting qubits, but is applicable to any quantum
computing platform that faces coherence-limited opera-
tion.
Furthermore, this control architecture can be extended
to larger-distance circuits such as the surface code. How-
ever, in the current implementation, the size of the lookup
table limits the number of syndrome measurements that
can be processed simultaneously [27]. Future develop-
ment will target the hardware implementation of the
decoder [33], possibly using neural networks to optimize
performance [34].
5ACKNOWLEDGMENTS
We thank G.E. Rowlands, D. Ellard, and G.J. Ribeill
for their contributions to the software stack underlying
this work, B. Hassick and A. Kreider for experimental
assistance, M. Takita, A.D. Co´rcoles, B. Abdo, J.M. Chow
for work on the qubit and Josephson amplifier devices.
This research was funded by the Office of the Director
of National Intelligence (ODNI), Intelligence Advanced
Research Projects Activity (IARPA), through the Army
Research Office Contract No. W911NF-14-1-0114.
[1] M. A. Nielsen and I. L. Chuang, Quantum Computation
and Quantum Information: 10th Anniversary Edition
(Cambridge University Press, 2010).
[2] E. Knill, Quantum computing with realistically noisy
devices, Nature 434, 39 (2005).
[3] D. P. DiVincenzo and P. Aliferis, Effective fault-tolerant
quantum computation with slow measurements, Phys.
Rev. Lett. 98, 020501 (2007).
[4] C. Chamberland, P. Iyer, and D. Poulin, Fault-tolerant
quantum computing in the Pauli or Clifford frame with
slow error diagnostics, Quantum 2, 43 (2018).
[5] P. Schindler, J. T. Barreiro, T. Monz, V. Nebendahl,
D. Nigg, M. Chwalla, M. Hennrich, and R. Blatt, Experi-
mental repetitive quantum error correction, Science 332,
1059 (2011).
[6] V. Negnevitsky, M. Marinelli, K. K. Mehta, H.-Y. Lo,
C. Flu¨hmann, and J. P. Home, Repeated multi-qubit
readout and feedback with a mixed-species trapped-ion
register, Nature 563, 527 (2018).
[7] J. Kelly, R. Barends, A. G. Fowler, A. Megrant, E. Jef-
frey, T. C. White, D. Sank, J. Y. Mutus, B. Campbell,
Y. Chen, Z. Chen, B. Chiaro, A. Dunsworth, I.-C. Hoi,
C. Neill, P. J. J. O’Malley, C. Quintana, P. Roushan,
A. Vainsencher, J. Wenner, A. N. Cleland, and J. M. Mar-
tinis, State preservation by repetitive error detection in a
superconducting quantum circuit, Nature 519, 66 (2015).
[8] N. Ofek, A. Petrenko, R. Heeres, P. Reinhold, Z. Leghtas,
B. Vlastakis, Y. Liu, L. Frunzio, S. M. Girvin, L. Jiang,
M. Mirrahimi, M. H. Devoret, and R. J. Schoelkopf, Ex-
tending the lifetime of a quantum bit with error correction
in superconducting circuits, Nature 536, 441 (2016).
[9] L. Hu, Y. Ma, W. Cai, X. Mu, Y. Xu, W. Wang, Y. Wu,
H. Wang, Y. P. Song, C.-L. Zou, S. M. Girvin, L.-M. Duan,
and L. Sun, Quantum error correction and universal gate
set operation on a binomial bosonic logical qubit, Nat.
Phys. 15, 503 (2019).
[10] C. K. Andersen, A. Remm, S. Lazar, S. Krinner, J. Hein-
soo, J.-C. Besse, M. Gabureac, A. Wallraff, and C. Eichler,
Entanglement stabilization using ancilla-based parity de-
tection and real-time feedback in superconducting circuits,
npj Quantum Inf. 5, 1 (2019).
[11] C. C. Bultink, T. E. O’Brien, R. Vollmer, N. Muthusub-
ramanian, M. W. Beekman, M. A. Rol, X. Fu, B. Tarasin-
ski, V. Ostroukh, B. Varbanov, A. Bruno, and L. Di-
Carlo, Protecting quantum entanglement from qubit
errors and leakage via repetitive parity measurements,
(2019), arXiv:1905.12731 [quant-ph].
[12] J. Cramer, N. Kalb, M. A. Rol, B. Hensen, M. S. Blok,
M. Markham, D. J. Twitchen, R. Hanson, and T. H.
Taminiau, Repeated quantum error correction on a con-
tinuously encoded qubit by real-time feedback, Nat. Com-
mun. 7, 11526 (2016).
[13] A. Paetznick and B. W. Reichardt, Universal fault-
tolerant quantum computation with only transversal gates
and error correction, Phys. Rev. Lett. 111, 090505 (2013).
[14] T. Jochym-O’Connor and R. Laflamme, Using concate-
nated quantum codes for universal fault-tolerant quantum
gates, Phys. Rev. Lett. 112, 010505 (2014).
[15] J. T. Anderson, G. Duclos-Cianci, and D. Poulin, Fault-
tolerant conversion between the Steane and Reed-Muller
quantum codes, Phys. Rev. Lett. 113, 080501 (2014).
[16] T. J. Yoder, R. Takagi, and I. L. Chuang, Universal fault-
tolerant gates on concatenated stabilizer codes, Phys. Rev.
X 6, 031039 (2016).
[17] A. G. Fowler, M. Mariantoni, J. M. Martinis, and A. N.
Cleland, Surface codes: Towards practical large-scale
quantum computation, Phys. Rev. A 86, 032324 (2012).
[18] Y. Tomita and K. M. Svore, Low-distance surface codes
under realistic quantum noise, Phys. Rev. A 90, 062320
(2014).
[19] B. Heim, K. M. Svore, and M. B. Hastings, Optimal
circuit-level decoding for surface codes, arXiv:1609.06373
[quant-ph] (2016), arXiv:1609.06373 [quant-ph].
[20] Qiskit/ibmq-device-information (2019).
[21] D. Riste`, M. P. da Silva, C. A. Ryan, A. W. Cross, A. D.
Co´rcoles, J. A. Smolin, J. M. Gambetta, J. M. Chow, and
B. R. Johnson, Demonstration of quantum advantage in
machine learning, npj Quantum Inf. 3, 16 (2017).
[22] M. Hatridge, R. Vijay, D. H. Slichter, J. Clarke, and I. Sid-
diqi, Dispersive magnetometry with a quantum limited
SQUID parametric amplifier, Phys. Rev. B 83, 134501
(2011).
[23] B. Abdo, F. Schackert, M. Hatridge, C. Rigetti, and
M. Devoret, Josephson amplifier for qubit readout, Ap-
plied Physics Letters 99, 162506 (2011).
[24] J. M. Chow, J. M. Gambetta, E. Magesan, D. W. Abra-
ham, A. W. Cross, B. R. Johnson, N. A. Masluk, C. A.
Ryan, J. A. Smolin, S. J. Srinivasan, and M. Steffen, Im-
plementing a strand of a scalable fault-tolerant quantum
computing fabric, Nat. Commun. 5, 4015 (2014).
[25] D. Riste`, C. C. Bultink, K. W. Lehnert, and L. DiCarlo,
Feedback control of a solid-state qubit using high-fidelity
projective measurement, Phys. Rev. Lett. 109, 240502
(2012).
[26] D. Egger, M. Werninghaus, M. Ganzhorn, G. Salis,
A. Fuhrer, P. Mu¨ller, and S. Filipp, Pulsed reset pro-
tocol for fixed-frequency superconducting qubits, Phys.
Rev. Appl. 10, 044030 (2018).
[27] See Supplemental Material.
[28] D. T. McClure, H. Paik, L. S. Bishop, M. Steffen, J. M.
Chow, and J. M. Gambetta, Rapid driven reset of a qubit
readout resonator, Phys. Rev. Appl. 5, 011001 (2016).
[29] C. A. Ryan, B. R. Johnson, D. Riste`, B. Donovan, and
T. A. Ohki, Hardware for dynamic quantum computing,
Rev. Sci. Instrum. 88, 104703 (2017).
[30] Y. Salathe´, P. Kurpiers, T. Karg, C. Lang, C. K. An-
6dersen, A. Akin, S. Krinner, C. Eichler, and A. Wallraff,
Low-latency digital signal processing for feedback and
feedforward in quantum computing and communication,
Phys. Rev. Appl. 9, 034011 (2018).
[31] S. Bravyi and A. Kitaev, Universal quantum computation
with ideal Clifford gates and noisy ancillas, Phys. Rev. A
71, 022316 (2005).
[32] B. Eastin and E. Knill, Restrictions on transversal en-
coded quantum gate sets, Phys. Rev. Lett. 102, 110502
(2009).
[33] S. J. Devitt, A. G. Fowler, T. Tilma, W. J. Munro, and
K. Nemoto, Classical processing requirements for a topo-
logical quantum computing system, Int. J. Quantum Inf.
08, 121 (2010).
[34] C. Chamberland and P. Ronagh, Deep neural decoders
for near term fault-tolerant experiments, Quantum Sci.
Technol. 3, 044002 (2018).
V. SUPPLEMENTAL MATERIAL
A. Methods
The real-time protocols presented in the manuscript
rely on the interconnection between the receivers (two
Innovative X6-1000M digitizers), the Processor (BBN
Trigger Distribution Module – TDM in Ref. [S1]), and
the Pulse Sequencers (BBN Arbitrary Pulse Sequencers
– APS2). The event sequence and the communication
between those instruments for the experiment in Fig. 3
in the main text are illustrated below.
1. Processor initializes Decoder for N cycles.
2. Pulse Sequencers perform the set of the gates for
the nth QEC cycle (all cycles are identical).
3. Pulse Sequencers perform a measurement on the
ancilla qubits At, Ab.
4. The ancilla qubit Receiver (Digitizer X6-1000M (A)
in Fig. S4) converts the readout signals into assigned
qubit states. The results {ant , anb } are fed back to
the Processor, which stores them in the appropriate
registers.
5. Repeat from step 2 until the N cycles are completed.
6. Processor loads the stored syndromes {ant , anb } for
n = 1...N
7. Decoding step: Processor calls a lookup table with
the mapping between the aggregate syndrome mea-
surements and the most likely bit flip errors [S2].
There are 8 possible decoder outputs, corresponding
to up to one bit flip for each of the 3 data qubits
(an even number of bit flips on the same qubit will
cancel each other).
8. Processor broadcasts the results of decoding to all
the Pulse Sequencers.
9. Pulse Sequencers issue the corrective Xˆ gates to the
appropriate data qubits.
10. Initialize Majority function.
11. Measure the data qubits D1, D2, D3.
12. The data qubit Receiver (Digitizer X6-1000M (B))
converts the readout signals into assigned qubit
states. The results {d1, d2, d3} are fed back to the
Processor, which stores them in the appropriate
registers.
13. Processor loads the stored {d1, d2, d3}. These re-
sults are also saved on the measurement computer
(Fig. 3b).
14. Processor applies the majority function on the bits
above.
15. Processor broadcasts the result to all the Pulse
Sequencers.
16. A Pulse Sequencer issues a digital output when
the majority output equals 1. This is acquired by
one of the digitizers and saved on the measurement
computer (Fig. 3c).
B. Classical hardware
To facilitate this sequence, key modifications were made
to the Pulse Sequencer and Processor gateware, relative to
the system described in Ref. [S1]. In particular the ‘steer-
ing logic’ was greatly expanded to enable the necessary
Processor functions. The logic defines the relationship be-
tween measured inputs and control commands broadcast
to the Pulse Sequencers.
First, acceleration engines were implemented on the
Processor. The two engines currently available support
the calculations necessary for the bit-flip code: Decod-
ing and Majority. The Decoding lookup table stores a
mapping of precomputed combinations relating syndrome
measurements and data qubit errors. Currently the table
supports up to eight cycles, with two ancilla measure-
ments per cycle. The Majority function, here used on the
final data qubit readout, can operate on up to 32 bits.
Second, to store measurement and calculation results,
4 kB of block RAM is allocated on the Processor FPGA.
This memory allows the Processor to accumulate mea-
surement results to be used by the engines (Fig. 1c).
Calculation results are also stored in this memory, at
separate addresses from the measurement results.
Section IV of Ref. [S1] describes the original communi-
cation capability between Pulse Sequencers and Processor.
Broadcasts from the Processor were limited to triggers
and the results of one-time measurements. Consequently,
for this work, the one-way SATA communication link was
modified to support additional data transfer functional-
ity. The link now also supports address and data pair
transfers (sent as an eight-byte message). In this way,
the Processor can transmit selected contents of its block
RAM, such as engine results, to all Pulse Sequencers. In
the case of active correction, a Pulse Sequencer utilizes
this information to emit a pulse 590 ns after the last
measurement result is made available (Table S1).
Control functions have been integrated into a publicly-
available software stack [S5] to initialize the steps in
Sec. V A and manage the address space in the Processor
block RAM.
70.0 5.0 10.0
time (μs)
CR
D2At
CR
D2Ab
CR
D1At
CR
D3Ab
M(A
t
)
M(A
b
)
M(D
2
)
M(D
1,
D
3
)
X
-pi/2
(A
t
)
X
-pi/2
(A
b
)
Conditional
X(D
2
)
X(D
1
)
X(D
3
)
1 cycle
D
2 
control
D
1 
control
D
3 
control
A
t 
control
A
b 
control
A
t 
measure
A
b 
measure
D
2 
measure
D
1
,
 
D
3 
measure
FIG. S1. Detailed gate circuit for the active correction case of Fig. 3 and N = 2. All pulses are generated by BBN APS2 pulse
sequencers [S1] and upconverted with I/Q mixers to the desired qubit and cavity frequencies (see Table S2). For simplicity, only
one channel per I/Q pair is shown and state preparation is omitted. Single-qubit gates are implemented with a diatomic Clifford
library made of Xpi/2 and partial Z rotations [S3]. CNOT gates are implemented by concatenating echo cross-resonance (CR)
pulses with the appropriate single-qubit gates [S4]. For each qubit, a single channel is used to produce its own gates and all the
CR tones where it plays the role of the control qubit. Thus, for example, the D2 channel switches coherently between fD2, fAt,
and fAb to implement the CNOT targeting At first, followed by one targeting Ab (see Figs. 1a, S4). This is achieved using the
on-board fast frequency hopping developed in Ref. [S1]. Measurement pulses are also generated by one I/Q pair per qubit, with
the exception of D1, D3, whose pulses are combined and applied simultanously to both qubits.
Step Latency (ns)
Receiver to Processor interface 20
Measurement storage in RAM 50
Engine initialization and calculation 150
Processor to PS module interface (8 bytes) 210
PS branching and waveform preparation 130
DAC output 30
Total 590
TABLE S1. Additional latency after qubit state assignment.
Latency includes the time to execute a Processor Engine,
broadcast its results, and play corrective pulses from a Pulse
Sequencer (PS).
VI. NUMERICAL SIMULATIONS
In this section we describe the model and methods used
to obtain the numerical simulation results shown in the
main text. We chose not to do a full time-dependent mas-
ter equation simulation of the error correction, as such an
open system simulation is numerically intensive. Further,
for the real-time error correction with ancilla reset, inter-
spersing strong measurement and conditional operations
within a time-dependent evolution is a nontrivial task.
Instead, we use a simulation model that is approximate,
but with well-controlled error that does not significantly
reduce the accuracy of our results. We aim for qualitative
agreement with the experimental results using a model
with no fit parameters (i.e. we do not search amongst
models for a best fit to the data), with all free parameters
in our model determined by independent characterization
of the device.
Each round of the error correction can be thought of
as an entangling operation (CNOT gates), followed by a
measurement operation, followed by an optional correction
and ancilla reset operation. This can be represented by
the following composition of linear maps
ρi+1 = Rm ◦M ◦ E (ρi) , (S1)
where ρi is the state after the i’th round of error correc-
tion, and E ,M, andRm are the entangling, measurement,
and correction/reset operations respectively, with the cor-
rection/reset operation being conditional on the vector of
ancilla measurement outcomes m. We now describe how
we simulate each of these operations in detail.
A. The Entangling Operation
The ideal entangling operation is a sequence of CNOT
gates between the data and ancilla qubits. We account for
experimental imperfections in two ways, which roughly
correspond to a separation of the coherent and incoherent
error. We account for coherent error in the CNOT gates
using one of two models. Our first model for coherent error
8Qubit f01 (GHz) T
∗
2 (µs) T1(µs) ηkn (kHz) ¯ 1q 2q
At 5.313 26± 8 48± 9 30 (ηt1);
25 (ηt2)
0.075 0.003
0.07 (D1);
0.075 (D2)
Ab 5.362 39± 6 49± 2 8 (ηb2);
35 (ηb3)
0.135 0.004
0.07 (D2);
0.035 (D3)
D1 5.412 12± 4 29± 4 32 (η12) 0.25 0.0015
D2 5.220 10± 1 7.7± 0.6 72 (η23) 0.13 0.01
D3 5.408 38± 11 42± 4 0.22 0.001
TABLE S2. Device parameters. ηkn indicate the static crosstalk terms in Eq. (S3). ¯ is the single-qubit readout assignment
error, averaged over the two states. For each of D1, D2, D3, we also average this error over the state of the other two data qubits,
to account for the crosstalk arising from their simultaneous measurement. The crosstalk between At and Ab is negligible.  denote
the average single- and two-qubit (target qubit between brackets) Clifford gate errors obtained by randomized benchmarking [S6].
This device was also used in Ref. S7 in a separate cooldown.
         
 1 X P E H U  R I  F \ F O H V N
   
   
   
   
   
   
⟨P
t⟩⟩
⟨P
b⟩
⟨Pt⟩⟩ |000⟩
⟨Pt⟩⟩ |111⟩
⟨Pb⟩⟩ |000⟩
⟨Pb⟩⟩ |111⟩
         
 1 X P E H U  R I  F \ F O H V N
   
   
   
   
   
   
⟨P
tP
b⟩
|000⟩
|111⟩
(c)
(a)
(d)
                               
|D1D2D3⟩
   
   
   
   
   
   
 - R
 L Q
 W  D
 V V
 L J
 Q P
 H Q
 W  S
 U R
 E D
 E L
 O L W
 \
 H H
 H R
 R H
 R R
(b)
depletion
D
2
D
1
A
t
D
3
A
b
depletion
N=1
p
b
N=2...
p
t
FIG. S2. (a) Repeated stabilizer measurement. pt(b) = e/o is
the single-shot parity assigned to the corresponding data qubit
pair, with e↔ 0 and o↔ 1 indicating their relation to at(b).
(b) Probability to detect joint parity ee, eo, oe, and oo for N =
1 cycle of Fig. 1b and each of the 8 D1D2D3 computational
states as input. (c) Average result of the individual parity
measurements at (circles) and ab (squares), as a function of
number of cycles N , for initial states |000〉 (blue) and |111〉
(red). (d) Same as (c), but displaying the average of the joint
parity measurement atab. Note that the ancillas are not reset
between cycles.
in the CNOT gates is that there is some over-rotation
in the ZX-interaction, and stray ZZ-coupling between
connected pairs of qubits. The CNOT gate on data qubit
d and ancilla qubit a is described by the unitary
Uˆad = Zˆ
d
90Xˆ
a
90 exp
(
−iHˆad tad
)
, (S2)
where Zˆd90 (Xˆ
a
90) is a single qubit 90
◦ rotation on data
qubit d (ancilla qubit a) about the Z (X) axis, which
we assume is perfect. The cross-resonance interaction
Hamiltonian is given by
Hˆad =
pi/2 + βda
2tad
Zˆd ⊗ Xˆa +
∑
k,n∈C
ηknZˆk ⊗ Zˆn, (S3)
where we use a compact notation for our operators that
assumes an identity operator on a qubit unless otherwise
written.
Here tad and ηkn are the gate length, and experimentally
characterized ZZ-coupling matrix. The set C describes
all qubits that are connected by a resonator (such that
a stray ZZ-coupling exists) but with connections to the
data qubit d removed. This is because we implement a
single-echo CR gate [S8, S9], which cancels the leading
order effect of stray ZZ-coupling with the data qubit.
The angle βda characterizes the over-rotation error, which
we estimate from 2-qubit randomized benchmarking (RB)
of our CNOT gates. This is an overestimate of the ro-
tation error, as both decoherence and ZZ-coupling also
contribute to the RB decay. However, we take an overly
cautious view of our device performance and attribute all
of the RB decay to over-rotation error.
It is important to note that the Hamiltonian in Eq. (S3)
is a simplification of the actual time-dependent Hamil-
tonian describing the fact that there is a pulse-shape
associated with the CR drive. The dynamics generated
by such a time-dependent Hamiltonian and Eq. (S3) are
equivalent if there is no ZZ-coupling. When ZZ-coupling
is present, the time-dependent version of Eq. (S3) no
longer commutes with itself at different times, and the
9FIG. S3. Repeated parity measurements for the computational states complementary to Fig. S2.
S1 2S
12 S
12
D1 D2At
D3 Ab
S
12
S
12
D
1
2
S
JPA
Yoko
LNF
LNF
Caltech
Vaunix 
Labbrick
LiConn
S
12
Agilent
E8257D
D3
D1
At D2Ab
Holzworth 
HS9004
Ch1 Ch2Ch1 Ch2
Ch1 Ch2 Ch1 Ch2
Ch1 Ch2 Ch1 Ch2
Ch3 Ch4
2
1
S
2
1
S
2
1
S
X6-1000M (A)
ChA ChB
ChA
Krytar 
120420
20 dB 20 dB
10 dB
20 dB 20 dB40 dB
MiniCircuits
VHF6010
20 dB
6 dB
3 dB
300 K
4 K
100 mK
700 mK
10 mK
K&L
6L250-00089
LNF
ChB
D1
CRD1At
D3
CRD3AbM(D1, D3)
At
Ch1 Ch2
JPC
Ab
Yoko
S1 2S1 2 S1 2
S1 2
M(At)
D2
CRD2At
CRD2Ab
M(D2)
M(Ab)
Labbrick
Labbrick
Labbrick
2
1
S
X6-1000M (B)
FIG. S4. Detailed wiring from room temperature through the various stages of the Bluefors refrigerator housing the qubit
device. The pulse waveforms produced by the Pulse Sequencers are input to the ports of IQ mixers and upconverted to qubit or
resonator frequencies (see also Fig. S1).
10
expression in Eq. (S2) is not the full transformation, but
the leading order approximation via a Magnus expansion.
While it is important to point out these (and other) dis-
crepancies between theory and experiment, we do not
believe that they have a significant enough effect to di-
minish the qualitative conclusions of our simulations.
Our second model for coherent error also uses the uni-
tary of Eq. (S2) generated by Eq. (S3), but with βda = 0
for all data-ancilla pairs (keeping the stray ZZ-coupling).
Instead, we model the ancilla qubit error probabilistically,
using the experimentally measured probabilities, γa, that
either of the ancilla qubits have erroneously changed state
after the entangling operation (i.e. conditioned on no data
qubit error). We draw a pseudorandom number s, and if
s < γa we say that an error has occurred and flip the state
of the ancilla qubit. This probabilistic model for coherent
error is in fact not coherent, but is rather the incoherent
approximation to the coherent error sources that cause
ancilla qubit flips. In our simulations, the ancilla flips
are (potentially) implemented after the CNOT unitary
operation.
We include incoherent error by introducing decoherence
due to qubit relaxation (T1) and dephasing (T2). We fol-
low our imperfect unitary with a decoherence operation
Ntad , which we implement using the Kraus operator for-
malism [S10]. This operation implements an amplitude
and phase damping channel on all qubits (data and an-
cilla) using the experimentally characterized values of T1
and T2 for a time duration t
a
d that is the length of the
CNOT gate on data qubit d and ancilla qubit a.
The complete circuits for the entangling operation for
both models of the coherent error are given by
E1 = Nτ2 ◦ U22 ◦ U31 ◦ Nτ1 ◦ U12 ◦ U21 , (S4)
E2 = AF ◦ Nτ2 ◦ U22 ◦ U31 ◦ Nτ1 ◦ U12 ◦ U21 , βad = 0,
(S5)
where Uad (ρ) = Uˆad ρ(Uˆad )†, and AF is the probabilistic
ancilla flip of coherent error model 2. This circuit encodes
that fact that the CNOT gates are done simultaneously
in pairs, and as such τ1 = max[t
2
1, t
1
2] and τ2 = max[t
3
1, t
2
2].
In practice, we find minimal difference between the simu-
lation results of the two circuits, and the results presented
in the main text have used the second model of coherent
error, given by E2.
This separation of decoherence from the unitary opera-
tion is an approximation, and a more physically accurate
picture would arise from solving the time-independent
master equation
ρ˙ = −i
[
Hˆad , ρ
]
+
∑
n
(
1
T
(n)
1
D [σˆ−] + 1
2T
(n)
φ
D[Zˆ]
)
ρ,
(S6)
for a duration tjk for the CNOT gate on qubits dj and ak.
Here D[xˆ]ρ = xˆρxˆ† − {xˆ†xˆ, ρ} /2 is the usual dissipator,
and Tφ = 2T1T2/(2T1 − T2) is the pure dephasing rate.
The summation indexed by n is over all qubits (data
and ancilla) which in general have different coherence
times. Our decomposition into separate decoherence and
unitary operations captures the dominant effects of the
full simulation, and is accurate to the level we desire. It
also considerably simplifies the composition of multiple
CNOTs on different qubits into the full operation E .
B. The Measurement Operation
To simulate strong quantum measurement we use a
stochastic quantum simulation technique. After each
entangling operation, we calculate the probability that
each ancilla is in its excited state
p(a)e = Tr [|e〉〈e|a E (ρi)] . (S7)
We then generate two pseudorandom numbers, r(a). If
r(a) < p
(a)
e , we project ancilla a to the excited state, and
renormalize the density matrix. Otherwise, we project to
the ground state and renormalize.
This approach introduces probabilistic trajectories to
our simulation, and each set of states {ρi} describes a
round-by-round history of the system evolution for one
particular trajectory. We perform this simulation many
times to generate sufficient realizations of the stochastic
evolution to calculate the average evolution
ρ¯i = E
[
ρki
]
=
1
K
∑
k
ρki (S8)
where ρki is the k’th realization of the simulation at the
i’th round, and K is the total number of realizations. In
practice we have chosen K = 105.
We introduce noise into the measurement operation in
the following ways. We simulate decoherence during the
measurement process by following or preceding the an-
cilla state projection by the phase and amplitude damping
channel described in the previous section. As before, we
implement this decoherence on all qubits, for the measure-
ment time tm, and our simulations show little noticeable
difference between these orderings of the decoherence
channel and the projection operation.
To simulate measurement infidelity we again use a
stochastic technique. For each trajectory, at each round
we store the measurement results for later use in our
decoder during the correction operation. We draw a
second pair of random numbers, and if either of these is
less than the corresponding measurement infidelity, we
flip the value of the stored result for that ancilla. We
emphasize that we are not flipping the state of the ancilla
in ρki but only of the stored classical bit representing the
measurement outcome.
Finally, we also simulate measurement back-action on
the measured ancilla qubit using a stochastic technique.
As before, we draw a third pair of random numbers, and if
either of these is less than the corresponding measurement
back-action rate, we flip the state of the ancilla, by acting
11
directly on ρki . For both the measurement infidelity and
measurement back-action rates, we use values obtained
from the experimental characterization of measurement
we have performed for each ancilla qubit in our device.
This measurement back-action comes from effects not
captured by the standard description of dispersive mea-
surement in circuit QED, which is usually considered to
be quantum non-demolition [S11]. These effects can have
a variety of sources [S12–S17], and can be either incoher-
ent or coherent. Our device characterization indicates
that for our experiment these effects are likely incoherent,
hence the model we have chosen.
C. The Correction and Reset Operation
The final operation in our simulations is (optional)
correction of the data qubits, and (optional) reset of the
ancilla qubits. For simulations with no error correction at
all (which form the baseline control experiment), nothing
occurs during this operation. For multi-round decoding
using the decoder from Ref. [S2], the correction operation
happens only after the final round. In this case, m is a
2×N matrix containing the ancilla measurement results
for N rounds of error correction. The multi-round decoder
takes as input m, and outputs a correction operation,
consisting of either identity or Xˆ gates applied to each
data qubit, to apply to ρkN (as a reminder k indexes the
trajectory). We assume this correction operation can be
done without error, as it need not be done in physical
hardware, but only in software frame-tracking (see main
text).
For repeated single-round error correction, the correc-
tion operation happens after every round, and is therefore
applied to each ρki . Here, m is a 2× 1 vector containing
the ancilla measurement outcomes for only the i’th round.
No decoder is necessary to determine the correction in
this case, as the values of m determine which data qubits
should be flipped. The operator Cˆ1 ⊗ Cˆ2 ⊗ Cˆ3 is applied
to ρki , with each Cˆi ∈ {Iˆ, Xˆ}. This is followed by a condi-
tional flip (i.e. reset) of the ancilla qubits, that depends
on m.
As the repeated single-round correction must be ap-
plied in hardware, we believe it is worthwhile to simulate
error in the correction operation. We add additional deco-
herence before the correction gates, using the same phase
and amplitude damping channel as before (on all qubits).
This is to account for the lag time between measurement
and correction, during which the hardware determines
the appropriate correction. We also introduce errors into
the the correction gate Xˆ in one of two ways. The first
is an incoherent error model, where we assume that with
some probability (which can be determined from the ex-
perimentally characterized Xˆ gate error) the Xˆ gate fails,
and nothing happens to the qubit. As we have done
for all other stochastic processes in our simulation, we
implement this probabilistic failure using pseudorandom
number sampling.
The second possible way to implement errors is by
including the stray ZZ-interactions into the correction
gate via the Hamiltonian
Hˆcor =
pi
2t1q
Cˆ1Cˆ2Cˆ3Cˆ4Cˆ5 +
∑
k,n∈A
ηknZˆkZˆn, (S9)
where Cˆi ∈ {Iˆ, Xˆ} are the correction operators for the
data and ancilla qubits, with t1q the single-qubit gate
time. We have suppressed the tensor product symbols for
brevity of notation. The set A consists of all connected
qubits such that a ZZ-interaction exists between them.
Our imperfect correction unitary is thus given by
Uˆcor = exp
(
−iHˆcort1q
)
. (S10)
Following this unitary, we implement a final decoherence
operation on all qubits for a length equal to the single-
qubit gate time t1q. We again find little quantitative
difference between the simulation results with these two
reset error models.
[S1] C. A. Ryan, B. R. Johnson, D. Riste`, B. Donovan, and
T. A. Ohki, Review of Scientific Instruments 88, 104703
(2017).
[S2] Y. Tomita and K. M. Svore, Phys. Rev. A 90, 062320
(2014).
[S3] D. C. McKay, C. J. Wood, S. Sheldon, J. M. Chow, and
J. M. Gambetta, Phys. Rev. A 96, 022330 (2017).
[S4] J. M. Chow, J. M. Gambetta, E. Magesan, D. W. Abra-
ham, A. W. Cross, B. R. Johnson, N. A. Masluk, C. A.
Ryan, J. A. Smolin, S. J. Srinivasan, and M. Steffen,
Nature Communications 5, 4015 (2014).
[S5] “BBN-Q/QGL,” (2019).
[S6] E. Magesan, J. M. Gambetta, B. R. Johnson, C. A.
Ryan, J. M. Chow, S. T. Merkel, M. P. da Silva, G. A.
Keefe, M. B. Rothwell, T. A. Ohki, M. B. Ketchen, and
M. Steffen, Phys. Rev. Lett. 109, 080505 (2012).
[S7] L. C. G. Govia, G. J. Ribeill, D. Riste`, M. Ware,
and H. Krovi, arXiv:1902.10821 [quant-ph] (2019),
arXiv:1902.10821 [quant-ph].
[S8] A. D. Co´rcoles, J. M. Gambetta, J. M. Chow, J. A.
Smolin, M. Ware, J. Strand, B. L. T. Plourde, and
M. Steffen, Phys. Rev. A 87, 030301 (2013).
[S9] M. Takita, A. D. Co´rcoles, E. Magesan, B. Abdo,
M. Brink, A. Cross, J. M. Chow, and J. M. Gambetta,
Phys. Rev. Lett. 117, 210505 (2016).
[S10] M. A. Nielsen and I. L. Chuang, Quantum Computation
and Quantum Information: 10th Anniversary Edition
(Cambridge University Press, 2010).
[S11] A. Blais, R.-S. Huang, A. Wallraff, S. M. Girvin, and
R. J. Schoelkopf, Phys. Rev. A 69, 062320 (2004).
12
[S12] M. Boissonneault, J. M. Gambetta, and A. Blais, Phys.
Rev. A 77, 060305 (2008).
[S13] D. H. Slichter, R. Vijay, S. J. Weber, S. Boutin, M. Bois-
sonneault, J. M. Gambetta, A. Blais, and I. Siddiqi,
Phys. Rev. Lett. 109, 153601 (2012).
[S14] L. C. G. Govia and F. K. Wilhelm, Phys. Rev. A 93,
012316 (2016).
[S15] L. C. G. Govia and F. K. Wilhelm, Phys. Rev. Appl. 4,
054001 (2015).
[S16] M. Malekakhlagh, A. Petrescu, and H. E. Tu¨reci,
arXiv:1809.04667 [cond-mat, physics:quant-ph] (2018),
arXiv:1809.04667 [cond-mat, physics:quant-ph].
[S17] A. Petrescu, M. Malekakhlagh, and H. E. Tu¨reci,
arXiv:1908.01240 [cond-mat, physics:quant-ph] (2019),
arXiv:1908.01240 [cond-mat, physics:quant-ph].
