# **A Method to Reduce Resources for Quantum Error Correction**

Ritajit Majumdar $^{1(\boxtimes)}$ , Saikat Basu<sup>2</sup>, and Susmita Sur-Kolay<sup>2</sup>

<sup>1</sup> B.P. Poddar Institute of Management and Technology,

Maulana Abul Kalam Azad University of Technology, Kolkata, India majumdar.ritajit@gmail.com

<sup>2</sup> Advanced Computing and Microelectronics Unit, Indian Statistical Institute, Kolkata, India

Abstract. In a quantum logic circuit, the minimum number of qubits required in a quantum error-correcting code (QECC) to correct a single error was shown by Laflamme to be five. Due to the presence of multi-control gates in the circuit block for a 5-qubit QECC, this block cannot be readily implemented with present day technology. Further, the fault-tolerant decomposition of the QECC circuit block requires a large number of quantum logic gates (resources). In this paper, we (i) propose a smaller 5-qubit error detection circuit which can also correct a single error in 2 of the 5 qubits, and (ii) establish how to use a 3-qubit error correction circuit to correct the single errors when detected in the other 3 qubits. This approach to quantum error-correction circuit design, functionally equivalent to a 5-qubit QECC, yields a significant reduction in the number of quantum logic gates. For a given quantum logic circuit, we also provide a scheme to decide the locations where these error detection and error correction blocks are to be placed in attaining reduction in gate requirement compared to the case where the original 5-qubit QECC block is used. A comparative study of the resource requirement for the benchmark circuits shows that the proposed method outperforms even Shor and Steane codes in terms of resources. Thus, our proposed method provides quantum error correction with minimum qubit requirement and reduced resource requirement on the average.

# **1 Introduction**

The evolution of a quantum state is mathematically represented by a unitary transformation. Quantum computing is reversible since any unitary matrix  $U$ has an inverse which is equal to its complex conjugate  $(U^{\dagger})$ . However, the state of interest, which is referred to as the system, may be coupled with some other quantum state, which is referred to as the environment. When this composite system undergoes some unitary evolution, the evolution of the constituent states may not be unitary. This incorporates error in the quantum system. An error is nothing but an operator. It is best represented when the state of the system is denoted by the density matrix notation [\[1](#page-10-0)[,2](#page-10-1)] as  $\rho = \sum p_i |\psi_i\rangle\langle\psi_i|$  where  $p_i$  is the

*i*

-c Springer International Publishing AG 2017

I. Phillips and H. Rahaman (Eds.): RC 2017, LNCS 10301, pp. 151–161, 2017. DOI: 10.1007/978-3-319-59936-6 12

probability that the system is in the state  $|\psi_i\rangle$ . For a pure state  $|\psi\rangle$ , the density matrix is simply  $|\psi\rangle\langle\psi|$ . If an error E occurs on the state  $\rho$  with probability p, then the evolution of the state is denoted as

$$
E(\rho) = (1 - p)\rho + p \cdot E\rho E^{\dagger} \tag{1}
$$

A quantum error correcting code  $\mathcal R$  is a mapping such that the composition of  $\mathcal R$  with  $E$  gives back the original quantum state, i.e.,

$$
(\mathcal{R} \circ E)(\rho)(E^{\dagger} \circ \mathcal{R}^{\dagger}) = \rho \tag{2}
$$

An error in a quantum system can also be modelled as a quantum channel. Some quantum error models include Amplitude damping channel, Phase damping channel and Pauli channel [\[1](#page-10-0)[,2](#page-10-1)]. In this paper, we have considered the Pauli channel as the error model. The Pauli matrices  $\mathbb{I}, X, Z$  and Y form the basis for  $2 \times 2$  dimensional operator space [\[1\]](#page-10-0). Hence a code which can correct the Pauli errors can also correct any linear combination of them, i.e., all errors in the  $2\times 2$ space. If the error probability is p and the probability of each of  $X$ ,  $Z$  and  $Y$ errors is considered to be equal (I implies no error and hence is not considered), then the evolution of the quantum system is given as

$$
E(\rho) = (1 - p)\rho + \frac{p}{3}(X\rho X^{\dagger} + Z\rho Z^{\dagger} + Y\rho Y^{\dagger})
$$
\n(3)

# <span id="page-1-0"></span>**2 Resource Requirement for 5-Qubit QECC**

A quantum operation may be realized by one or more quantum gates forming a network of gates or a circuit. Given a quantum system for performing certain operations, a quantum circuit has to be obtained with minimum number of gates, which are also termed as resources. The depth of the circuit and the number of operations to be executed are also important factors in designing a quantum circuit. Additionally, such a circuit requires quantum error correcting code (QECC) for error-free operations. But the QECC also requires a circuit block to be designed appropriately.

Several QECCs have been proposed in the literature to correct a single error in a qubit [\[3](#page-10-2)[–6](#page-10-3)]. Gottesman has provided a group theoretic model of errors in a quantum system. His stabilizer formulation provides an operator-level mechanism for correcting quantum errors [\[7\]](#page-10-4). It has been shown by Laflamme et al. [\[5](#page-10-5)] that in order to correct a single error in a qubit, the information of the qubit must be distributed into at least 5 qubits. An important aspect of this code by Laflamme is that the encoding and the decoding circuits are identical. Furthermore, it is extremely difficult to maintain the superposition of a qubit. Hence, the 5-qubit code provides a better option for error correction than the other codes [\[3](#page-10-2),[4,](#page-10-6)[6\]](#page-10-3).

The encoding and decoding circuits of the 5-qubit code, proposed by Laflamme [\[5](#page-10-5)], has a number of multi-control gates, which cannot be implemented readily in modern day technologies. Due to the presence of these multi-control operations, the fault-tolerant decomposition requires a large number of gates. Also these gates can be noisy, and incorporate errors in the circuit. Moreover, the error correction requires a significant amount of time due to more gate operations and thus hinders the speed of the computation. FTQLS [\[8\]](#page-10-7) provides the fault-tolerant decomposition of any quantum circuit in different technologies viz. Ion Trap (IT), Quantum Dot (QD), Linear Photonics (LP), Non-linear Photonics (NP), Neutral Atom (NA) and Superconductor (SC). In Table [1,](#page-2-0) we compare the number of gate operations and the number of cycles per operation for Shor, Steane and Laflamme codes for each of the six available technologies, as obtained from FTQLS. It is evident from Table [1](#page-2-0) that while the qubit requirement of Laflamme code is low, the gate count is significantly larger than for the other two codes.

<span id="page-2-0"></span>**Table 1.** Comparison of gate count and number of cycles of both encoding and correction circuits for QECCs of Shor, Steane and Laflamme respectively

| QECC     |    |                |   | Technology Qubits Ancilla Total number of qubits Gate count Cycles |      |       |
|----------|----|----------------|---|--------------------------------------------------------------------|------|-------|
| Shor     | IT | 9              | 8 | $9 + 8 = 17$                                                       | 105  | 24    |
| Steane   |    | $\overline{7}$ | 6 | $7+6=13$                                                           | 85   | 30    |
| Laflamme |    | 5              |   | 5                                                                  | 1641 | 1432  |
| Shor     | QD | 9              | 8 | $9 + 8 = 17$                                                       | 133  | 116   |
| Steane   |    | $\overline{7}$ | 6 | $7+6=13$                                                           | 127  | 191   |
| Laflamme |    | 5              |   | 5                                                                  | 3353 | 19602 |
| Shor     | LP | 9              | 8 | $9 + 8 = 17$                                                       | 56   | 164   |
| Steane   |    | 7              | 6 | $7+6=13$                                                           | 55   | 172   |
| Laflamme |    | 5              |   | 5                                                                  | 1751 | 2310  |
| Shor     | NP | 9              | 8 | $9 + 8 = 17$                                                       | 56   | 196   |
| Steane   |    | 7              | 6 | $7 + 6 = 13$                                                       | 55   | 206   |
| Laflamme |    | 5              |   | 5                                                                  | 2437 | 2566  |
| Shor     | ΝA | 9              | 8 | $9 + 8 = 17$                                                       | 87   | 22    |
| Steane   |    | $\overline{7}$ | 6 | $7 + 6 = 13$                                                       | 95   | 29    |
| Laflamme |    | 5              |   | 5                                                                  | 1892 | 1657  |
| Shor     | SC | 9              | 8 | $9 + 8 = 17$                                                       | 84   | 196   |
| Steane   |    | 7              | 6 | $7+6=13$                                                           | 85   | 242   |
| Laflamme |    | 5              |   | 5                                                                  | 2604 | 9070  |

In order to overcome these shortcomings, we have proposed a smaller 5 qubit circuit for error detection which can also correct errors in 2 of the 5 qubits. Given a quantum circuit, one can insert this detection circuit block at certain points in the given circuit so that if an error is likely to be detected, only then the correction circuit block is also placed. We have computed the time interval for placing this error detection block to obtain reduction in resources. We have also shown the percentage savings in the resource requirement for different benchmark circuits using this proposed technique.

Shor and Steane codes require more qubits for error correction than the code by Laflamme (refer Table [1\)](#page-2-0). However, the resource requirement of the former two is much less than for the 5 qubit code. Hence once can argue that these two codes be used rather than the proposed technique which requires both detection and correction steps in the worst case. However, we show that in average case, our proposed technique requires less resources than the Shor and Steane codes too. Hence, this technique is superior both in terms of qubits as well as resources.

The paper has been organised as follows. In Sect. [2](#page-1-0) we propose a new quantum circuit for error detection and compute the time interval for placing this block in a quantum circuit. Section [3](#page-3-0) shows the use of the error detection circuit along with a 3 qubit error correction circuit to replace the error correction circuit of the 5 qubit code. We also show the percentage savings provided by this method. In Sect. [4,](#page-6-0) we show the percentage savings in different benchmark circuits. We conclude in Sect. [5.](#page-7-0)

# <span id="page-3-0"></span>**3 5-Qubit Quantum Error Detection Circuit**

In classical computing, error may cause the bit to flip from 0 to 1 or vice versa. However, in quantum computing, a qubit can incur bit flip or phase flip errors, or both [\[9\]](#page-10-8). Thus quantum error correction has two requirements: detection of the type of error and detecting the location of the error. While the former operation is possible using 4 qubits only [\[10\]](#page-10-9), at least 5 qubits are necessary for both operations [\[5\]](#page-10-5). A code which is capable of detecting only the type of error is called a quantum error detection code, while a quantum error correction code can both detect the type and its location. Qubit is an essential resource which must be minimized in quantum computation. This is because it is difficult to preserve the superposition nature of a qubit. Any modification of the original superposition results in loss of information [\[1](#page-10-0)]. So using 5-qubit code is preferable for error correction since it requires the minimum number of qubits. However, Table [1](#page-2-0) shows that this code has significantly large resource requirement.

In this paper, our proposal is to place a quantum error detection block at certain points in the circuit. If error is likely to be detected, only then the correction block is also placed there. However, the 4-qubit error detection code is not applicable here because encoding the information of a single qubit into 4 qubits only will not allow to correct errors when necessary. The qubit should be encoded using the 5-qubit code by Laflamme to allow error correction whenever necessary.

We propose a 5-qubit error detection block as shown in Fig. [1.](#page-4-0) This block can act on the 5-qubit system which has been encoded using Laflamme code. In Fig. [1,](#page-4-0)  $|q_0\rangle$  up to  $|q_4\rangle$  are the data qubits and the last four are ancilla qubits.  $|q_5\rangle, |q_6\rangle$  check for bit error while  $|q_7\rangle, |q_8\rangle$  check for phase errors. This block checks whether the first four and the last four qubits are in the same state. If they are not, then an error is detected. Instead of the error correcting block in [\[5\]](#page-10-5),



<span id="page-4-0"></span>**Fig. 1.** Proposed 5-qubit error detection block

we place the detection block of Fig. [1](#page-4-0) after certain time interval. The correction block is placed at the location where an error is likely to be detected.

A salient question arises here: at which locations should the error detection and the error correction blocks be placed in a given quantum circuit? We provide a bound on the time interval that can be allowed between two error detection blocks, in terms of the probability of error. This time interval may vary with the technology used, since the probability of error at a quantum gate or of decoherence (memory error) differs with the technology for implementing it. Furthermore, if the error detection block is placed at intervals greater than this bound, then the larger error correction block is mandated and hence resource reduction cannot be achieved.

Let  $p$  be the error probability per nanosecond  $(ns)$ ,  $D$  and  $C$  be the gate count of the 5-qubit detection circuit and the 5-qubit correction circuit respectively. We consider that we check for errors at interval of n *ns*. The probability of no errors occurring after *n ns* is  $(1-p)^n$ , and hence the error probability is  $(1-(1-p)^n)$ . When a single error occurs, then the resource requirement is  $(D+C)$  since both error detection as well as correction block must be placed. It is only D when there is no error. So the resource requirement for each time error correction is performed, is

$$
(1-p)^n \cdot D + (1 - (1-p)^n) \cdot (D + C) \tag{4}
$$

<span id="page-4-1"></span>If this technique is not used, then after each time interval only the correction block is placed, i.e., the resource requirement is  $C$  each time. For our proposed method to be advantageous, the resource requirement of this method should be at most  $C$ , i.e.,

$$
(1-p)^{n} \cdot D + (1 - (1-p)^{n}) \cdot (D + C) \leq C \tag{5}
$$

A simple calculation gives us the following inequality

|                 | Technology # Gates for error correction $(C)$ # Gates for error detection $(D)$ $\frac{D}{C}$ |    |       |
|-----------------|-----------------------------------------------------------------------------------------------|----|-------|
| <b>IT</b>       | 843                                                                                           | 36 | 0.043 |
| $\overline{SC}$ | 1301                                                                                          | 34 | 0.026 |
| LP              | 874                                                                                           | 26 | 0.03  |
| NP              | 1217                                                                                          | 26 | 0.021 |
| NA              | 900                                                                                           | 34 | 0.038 |
| QD              | 1518                                                                                          | 52 | 0.034 |

<span id="page-5-0"></span>**Table 2.** Gate counts *<sup>D</sup>* and *<sup>C</sup>* for error detection and correction in various technologies

<span id="page-5-1"></span>
$$
(1-p)^n \ge \frac{D}{C} \tag{6}
$$

We have used FTQLS  $[8]$  to obtain the fault-tolerant version of the error correction block  $[5]$  $[5]$  and the error detection block (Fig. [1\)](#page-4-0). The ratio of D to  $C$  is provided in Table [2.](#page-5-0) Note here that in Table [1,](#page-2-0) we reported the total gate count for both encoding and correction blocks. However, since the encoding block remains same in both cases, in Table [2](#page-5-0) we have the gate count of the error correction block of the Laflamme code only to compare with the proposed error detection block.

In [\[11\]](#page-10-10), the authors have addressed error tracing in quantum circuits. They have placed error correction blocks only when the error probability exceeds a predefined threshold. This technique has allowed them to reduce the required number of error correction blocks significantly compared to the ideal case. Similarly, we propose that error correction can be performed after certain time gap of n *ns*. For different values of p, the inequality of [\(6\)](#page-5-1) enables us to the find the maximum permissible value of n for obtaining a circuit with very low probability of error. In Table [3,](#page-5-2) we give the estimated error probability in different technologies as obtained from [\[12\]](#page-10-11).

|                 | Technology   Probability of gate error   Memory error (per ns) |                        |
|-----------------|----------------------------------------------------------------|------------------------|
| QD              | $9.89 \times 10^{-1}$                                          | $3.47 \times 10^{-2}$  |
| $\overline{NA}$ | $8.12 \times 10^{-3}$                                          | 0.00                   |
| $L_{\rm P}$     | $1.01 \times 10^{-1}$                                          | $9.80 \times 10^{-4}$  |
| <b>NLP</b>      | $5.20 \times 10^{-3}$                                          | $9.80 \times 10^{-5}$  |
| <b>SC</b>       | $1.00 \times 10^{-5}$                                          | $1.00 \times 10^{-5}$  |
| <b>IT</b>       | $3.19 \times 10^{-9}$                                          | $2.52 \times 10^{-12}$ |

<span id="page-5-2"></span>**Table 3.** Probability of worst gate and memory error in different technologies [\[12](#page-10-11)]

In Table [4,](#page-6-1) we show the values of n for different values of  $p$  in the technologies considered. We have varied p from  $10^{-8}$  to  $10^{-1}$ . However, certain error

| Technology $p = 10^{-8}$ $p = 10^{-7}$ $p = 10^{-6}$ $p = 10^{-5}$ $p = 10^{-4}$ $p = 10^{-3}$ $p = 10^{-2}$ $p = 10^{-1}$ |          |          |          |          |          |      |     |    |
|----------------------------------------------------------------------------------------------------------------------------|----------|----------|----------|----------|----------|------|-----|----|
| IT                                                                                                                         | 84397007 | 8439701  | 843970   | 84397    | 8440     | 844  | 84  | 9  |
| <b>SC</b>                                                                                                                  | $\times$ | $\times$ | 3649657  | 364965   | 36495    | 3648 | 364 | 35 |
| $L_{\rm P}$                                                                                                                | $\times$ | $\times$ | $\times$ | 350655   | 35064    | 3505 | 349 | 34 |
| NP                                                                                                                         | $\times$ | $\times$ | 3863231  | 386322   | 38631    | 3862 | 385 | 37 |
| <b>NA</b>                                                                                                                  | $\times$ | 32701690 | 3270168  | 327016   | 32701    | 3269 | 326 | 32 |
| QD                                                                                                                         | $\times$ | $\times$ | $\times$ | $\times$ | $\times$ | 3380 | 337 | 33 |

<span id="page-6-1"></span>**Table 4.** Time interval  $n(ns)$  of error detection with error probability  $p$  ranging from 10*−*<sup>5</sup>/ns to 10*−*<sup>1</sup>/ns) for different technologies

probabilities are too low for some of the technologies; for example  $p = 10^{-9}$  for QD (see Table [3\)](#page-5-2) is not feasible. Such entries in Table [4](#page-6-1) are denoted by a ' $\times$ '.

Thus Table [4](#page-6-1) provides an upper bound of the time interval between placing two error detection blocks in a quantum circuit for a particular technology.

#### <span id="page-6-0"></span>**4 Savings in Resources by Our Proposed Method**

We consider the proposed quantum error detection circuit of Fig. [1](#page-4-0) once more. After the quantum error detection block is placed, one needs to check the syndromes in the 4 ancilla qubits, of which first two indicate bit error and last two indicate phase error. We consider only the bit flip error syndrome for the time being. If the syndrome is 00, it indicates that the circuit is free of bit error. If the syndrome is 10, it indicates that the last four qubits are in the same state, but the 1st four qubits are not. This is possible only if error has occurred in the 1st qubit. Similarly, if 01 is the syndrome, then it is possible to determine that the 5th qubit has error. However, if the syndrome is 11, then it is not possible to determine which of the remaining 3 qubit is erroneous. The similar is true for syndromes for phase flip errors too. Thus when there is any error on the 1st or last qubit, this error detection block can both identify the error type and its position; hence can correct it.

If error is in one of the other 3 qubits, then this proposed error detection circuit can detect it, but cannot determine its position uniquely. So we need to place the error correction block. However, when the error syndrome is 11, we are sure that the error is not in the first or last data qubit. Hence it is not necessary to place the 5-qubit error correcting block to correct errors in one of 3 qubits. Rather, we place a 3-qubit error correction block as shown in Fig. [2.](#page-7-1)

We now consider the worst case scenario, where an error has been detected by the error detection block of Fig. [1](#page-4-0) but this block cannot correct it. So we need to place the 3-qubit error correcting block of Fig. [2.](#page-7-1) In this scenario our proposed technique requires the maximum resource (5-qubit error detection + 3-qubit error correction). In Table [5,](#page-7-2) we show the percentage savings that the worst case scenario of our proposed technique gives over the ideal situation of placing a 5-qubit error correction block. From the table we see that for all technologies, our proposed technique provides an average reduction of 94.70% with respect to [\[5\]](#page-10-5).



<span id="page-7-1"></span>**Fig. 2.** 3-qubit error correcting block

<span id="page-7-2"></span>**Table 5.** Percentage savings by using the proposed technique over the 5-qubit QECC

|                                            | Technology   Ideal 5-qubit $EC$   Detection block   3-qubit $EC$   Total   Savings $(\%)$ |    |    |    |       |
|--------------------------------------------|-------------------------------------------------------------------------------------------|----|----|----|-------|
| <b>IT</b>                                  | 843                                                                                       | 36 | 28 | 64 | 92.4  |
| <b>SC</b>                                  | 1301                                                                                      | 34 | 22 | 56 | 95.7  |
| L <sub>P</sub>                             | 874                                                                                       | 26 | 14 | 40 | 95.4  |
| <b>NP</b>                                  | 1217                                                                                      | 26 | 14 | 40 | 96.7  |
| <b>NA</b>                                  | 900                                                                                       | 34 | 22 | 56 | 93.8  |
| QD                                         | 1518                                                                                      | 52 | 36 | 88 | 94.2  |
| Average savings $(\%)$ with respect to [5] |                                                                                           |    |    |    | 94.70 |

# <span id="page-7-0"></span>**5 Resource Savings Analysis**

In Table [5,](#page-7-2) we have shown the percentage savings compared to Laflamme code for worst case scenario. However, it is not expected that each time both the detection and correction block need to be placed. At a location where the probability of error is almost zero, placing the detection block alone is sufficient. In this section, we provide an analysis of the resource requirement.

In [\[11\]](#page-10-10), the authors have introduced the mechanism of error tracing for linear and concatenated Bacon-Shor  $[6]$  $[6]$ , Steane  $[4]$  $[4]$  and Knill  $C_4$  code  $[13]$  $[13]$ . 5-qubit error correction code was not used for error tracing purpose. Here, we use a similar approach for different error thresholds and compute the percentage savings in resources. Using the technique of [\[11](#page-10-10)], we propose placing the error correction and detection block after some predefined threshold. Let the error threshold be p*th*. So, we place both the detection and correction block only when the error

<span id="page-8-0"></span>

# **Table 6.** Comparative study of savings in different benchmark circuits

probability  $p = p_{th}$ . From Eq. [4,](#page-4-1) the expected resource requirement for placing the detection and/or correction block each time is

$$
(1 - p_{th})D + (1 - (1 - p_{th}))(D + C) = D + p_{th}C.
$$

This equation gives the expected resource requirement when the error detec-tion and/or correction block(s) are placed. In Table [6,](#page-8-0) we show the expected percentage savings in resource for different benchmark quantum circuits. In addition to comparing our technique with the ideal situation of placing the 5-qubit error correcting code, we also compare our proposed technique with Shor and Steane codes.

It can be observed from Table [6](#page-8-0) that Steane code has the minimum resource requirement of the three codes (Shor, Steane and Laflamme). The percentage savings shown in this table is with respect to Steane code only, since it has the minimum resource requirement. Our proposed technique shows an average resource reduction of 28.34% over Steane code [\[4](#page-10-6)].

Another observation from the benchmark table is that with the increase in probability threshold, the percentage savings decreases, i.e., the resource requirement of our proposed technique increases. This is natural because if when the error threshold is increased, the probability of error occurring increases. Hence, it is more likely to detect errors for higher threshold. So the probability that both detection and correction block needs to be placed increases with the increase in error threshold. Hence the resource requirement of the proposed technique also increases, resulting in a decrease in the percentage savings.

The resulting values from the benchmark circuits (Table  $6$ ) clearly show that our proposed technique has minimal resource requirement and minimum qubit requirement and hence is superior to all the three error correcting codes considered (Shor, Steane, Laflamme).

# **6 Conclusion**

In this paper we have proposed a technique to replace the 5 qubit error correction code. Though this code requires the minimum number of qubits, its resource requirement is extremely high since it contains a few multi-control gates. These gates cannot be directly implemented in a fault-tolerant manner, and the faulttolerant decomposition requires a large number of gates. Our proposed technique uses two steps: error detection, and if error is likely to be detected, then error correction. The total qubit requirement does not increase in this technique. One can still perform error correction with 5 qubits only. However, in the original 5 qubit code [\[5\]](#page-10-5), no ancilla qubits are required for error correction. But our proposed technique requires 4 ancilla qubits. Nevertheless, these qubits are all initialized to  $|0\rangle$  and the superposition property of these qubits are not necessary for the proposed mechanism. Hence effectively they behave like reversible bits and can be reused more than once.

We have shown the percentage savings that the technique proposed here provides. Furthermore, we have used our technique on some benchmark circuits too and have shown the savings in gate count. Hence, this method provides a way for performing error correction using the minimum number of qubits and also reduces the gate count significantly. A future prospect will be to find the minimum resource requirement for quantum error correction and to check where our proposed technique stands compared to it.

# <span id="page-10-0"></span>**References**

- 1. Nielsen, M.A., Chuang, I.L.: Quantum Computation and Quantum Information. Cambridge University Press, Cambridge (2010)
- <span id="page-10-1"></span>2. Wilde, M.M.: Quantum Information Theory. Cambridge University Press, New York (2013)
- <span id="page-10-2"></span>3. Shor, P.W.: Scheme for reducing decoherence in quantum computer memory. Phys. Rev. A **52**, R2493–R2496 (1995)
- <span id="page-10-6"></span>4. Steane, A.M.: Error correcting codes in quantum theory. Phys. Rev. Lett. **77**, 793–797 (1996)
- <span id="page-10-5"></span>5. Laflamme, R., Miquel, C., Paz, J.P., Zurek, W.H.: Perfect quantum error correcting code. Phys. Rev. Lett. **77**, 198–201 (1996)
- <span id="page-10-3"></span>6. Bacon, D.: Operator quantum error-correcting subsystems for self-correcting quantum memories. Phys. Rev. A **73**, 012340 (2006)
- <span id="page-10-4"></span>7. Gottesman, D.: Stabilizer codes and quantum error correction. arXiv preprint [arXiv:quant-ph/9705052](http://arxiv.org/abs/quant-ph/9705052) (1997)
- <span id="page-10-7"></span>8. Lin, C.C., Chakrabarti, A., Jha, N.K.: FTQLS: fault-tolerant quantum logic synthesis. IEEE Trans. Very Large Scale Integr. VLSI Syst. **22**(6), 1350–1363 (2014)
- <span id="page-10-8"></span>9. Gottesman, D.: An introduction to quantum error correction and fault-tolerant quantum computation. Quantum Inform. Sci. Contrib. Math. **68**, 13–60 (2009)
- <span id="page-10-9"></span>10. Grassl, M., Beth, T., Pellizzari, T.: Codes for the quantum erasure channel. Phys. Rev. A **56**, 33–38 (1997)
- <span id="page-10-10"></span>11. Majumdar, R., Basu, S., Mukhopadhyay, P., Sur-Kolay, S.: Error tracing in linear and concatenated quantum circuits. arXiv preprint [arXiv:1612.08044](http://arxiv.org/abs/1612.08044) (2016)
- <span id="page-10-11"></span>12. Suchara, M., Faruque, A., Lai, C.Y., Paz, G., Chong, F., Kubiatowicz, J.D.: Estimating the resources for quantum computation with the QuRE toolbox. Technical report, DTIC Document (2013)
- <span id="page-10-12"></span>13. Knill, E.: Quantum computing with realistically noisy devices. Nature **434**(7029), 39–44 (2005)