

## Part II : Fault-tolerance

### Lecture I : DEFINITION OF FAULT TOLERANCE ①

So far we have only considered error models where data qubits are affected by errors.

But what if the error correction circuits themselves are also noisy?

This is the case in  
current (and most likely)  
future quantum hardware.

How do we run long  
computations when all  
parts of the circuits are  
noisy?

Classical hardware is so  
reliable that we don't need  
to worry about this issue

# Fault tolerant error correction

(3)



Like putting out a  
fire with a fire extinguisher  
that is also on fire!

# Definition of fault

tolerance

Def : circuit noise  
error model

Given a circuit, break  
it up into locations,

where a location is a  
gate ( 1 qubit, 2 qubit, maybe  
3 qubit ), a measurement,

a state preparation

(generally 10<sup>2</sup>) , or

a storage / wait location .

Assume that classical

computations 'of modest

size' are perfect and

instantaneous .

what this  
means depends  
on context

For a location  $\ell$  assume

that with prob.  $1 - p_\ell$

the location functions as intended.

(6)

And with probability  $p_e$  the location  $\ell$  is replaced by an unknown quantum channel  $E_\ell$ . We usually assume that  $E_\ell$  maps qubits to qubits and that each error channel is independant. Commonly  $E_\ell$  just depends on the type of location.

(7)

We often assume

- state prep  $|0\rangle \rightarrow$



depolarizing  
channel  
w/ prob P

- gate  $\rightarrow \boxed{u} \rightarrow$



- measurement



Sometimes we use different error probabilities for different types of location e.g. 2-qubit gates are usually more error-prone than 1-qubit gates.

This is by no means the most general error model!  
[In a later lecture we will discuss extensions]

Fault-tolerance is

a surprisingly slippery concept to define.

The basic idea is that we encode the qubits of the circuit in a quantum error-correcting code and we replace each physical location with

a corresponding logical location. We want the logical locations to not spread errors 'too much'. We also periodically do error correction to prevent the build-up of errors.

This usually looks  
something like



physical  
circuit



**QECC**



logical circuit

bar denotes  
logical location

Defn : FT QEC

Let  $\mathcal{C}$  be an  $[[n, k, d]]$

stabilizer code & let

$t = \left\lfloor \frac{d-1}{2} \right\rfloor$ . An error

correction protocol for  $\mathcal{C}$

is FT if :

- ① For an input codeword  $|v\rangle$  with error of weight  $s_1$ , if  $s_2$  faults occur during

the protocol w/  $s_1 + s_2 \leq t$  (13)

then perfectly decoding  
the output state gives  $|x\rangle$ .

② For set faults occurring

during the protocol for  
an arbitrary input state  
the output state differs  
from a codeword by an  
error of weight  $\leq s$ .

① Ensures that correctable errors don't spread to uncorrectable errors during the course of the protocol.

To understand why ② is necessary let  $\frac{t}{n} < s < \frac{2t+1}{3}$

where  $n \in \mathbb{Z}^+$ , & consider a QEC protocol where  $r$  input errors and  $s$  errors during the protocol result

in an output with at ⑯ 15

most  $r+s$  errors. ① is satisfied.

Now suppose we apply the protocol  $j$  times



When  $j > n$  the input state to EC will have  $ns > t$

errors! Failure after linear

number of steps. :-

But if ② also holds

Input  $| \bar{t} \rangle$

After EC output is  $E_1 | \bar{t} \rangle$

where  $\text{wt}(E_1) \leq s$

After 2nd EC output is

$E_2 | \bar{t} \rangle$ , where  $\text{wt}(E_2) \leq 2s$

But by ② output is also

$E'_2 | \bar{\phi} \rangle$  where  $| \bar{\phi} \rangle$  is a codeword and  $\text{wt}(E'_2) \leq s$

$$E'_2 | \bar{\phi} \rangle = E_2 | \bar{t} \rangle$$

17

$$|\bar{\phi}\rangle = E_2' + E_2 |\bar{t}\rangle$$

$$\text{wt}(E_2' + E_2) \leq 3s$$

$$\text{as } \text{wt}(E_2) \leq 2s \text{ & } \text{wt}(E_2') \leq s$$

By assumption  $3s < \underbrace{2t+1}_d$   
 $\Rightarrow |\bar{t}\rangle = |\bar{\phi}\rangle$  code dist.

$$\text{wt}(E_2) = \text{wt}(E_2') \leq s$$

i.e



We can write similar  
defns for all location  
types e.g. for a logical  
gate if the input has  
 $s_1$  errors &  $s_2$  errors  
occur during the gate  
where  $s_1 + s_2 \leq t$  then  
ideally decoding the output  
gives the same thing as  
ideally decoding the input

after applying the gate  
with no errors.

Upshot : To construct a

FT circuit we need to

construct

- ① FT error correction
  - ② FT state prep
  - ③ FT measurement
  - ④ FT gates      Lecture 3 + 4
- Lecture 2

Aside : the defn

(20)

of fault-tolerance we just discussed is perhaps too stringent e.g. surface code error correction fails to satisfy this defn.

However it is the right defn for proving threshold thm w/ concatenated codes,

as we will see in

(21)

## Lecture 5.

### Post script

For an 'operational' defn of  
fault tolerance see

[arXiv.org/abs/1610.03507](https://arxiv.org/abs/1610.03507)

For a discussion of the  
defn of fault tolerance see

<https://youtu.be/FMXFNClaf3k>