Entanglement-assisted stabilizer formalism

From HandWiki

In the theory of quantum communication, the entanglement-assisted stabilizer formalism is a method for protecting quantum information with the help of entanglement shared between a sender and receiver before they transmit quantum data over a quantum communication channel. It extends the standard stabilizer formalism by including shared entanglement (Brun et al. 2006). The advantage of entanglement-assisted stabilizer codes is that the sender can exploit the error-correcting properties of an arbitrary set of Pauli operators. The sender's Pauli operators do not necessarily have to form an Abelian subgroup of the Pauli group [math]\displaystyle{ \Pi^{n} }[/math] over [math]\displaystyle{ n }[/math] qubits. The sender can make clever use of her shared ebits so that the global stabilizer is Abelian and thus forms a valid quantum error-correcting code.

Definition

We review the construction of an entanglement-assisted code (Brun et al. 2006). Suppose that there is a nonabelian subgroup [math]\displaystyle{ \mathcal{S}\subset\Pi^{n} }[/math] of size [math]\displaystyle{ n-k=2c+s }[/math]. Application of the fundamental theorem of symplectic geometry (Lemma 1 in the first external reference) states that there exists a minimal set of independent generators [math]\displaystyle{ \left\{ \bar{Z}_{1},\ldots,\bar{Z}_{s+c},\bar{X}_{s+1},\ldots,\bar{X}_{s+c}\right\} }[/math] for [math]\displaystyle{ \mathcal{S} }[/math] with the following commutation relations:

[math]\displaystyle{ \left[ \bar{Z}_{i},\bar{Z}_{j}\right] = 0\ \ \ \ \ \forall i,j, }[/math]
[math]\displaystyle{ \left[ \bar{X}_{i},\bar{X}_{j}\right] = 0\ \ \ \ \ \forall i,j, }[/math]
[math]\displaystyle{ \left[ \bar{X}_{i},\bar{Z}_{j}\right] = 0\ \ \ \ \ \forall i\neq j, }[/math]
[math]\displaystyle{ \left\{ \bar{X}_{i},\bar{Z}_{i}\right\} = 0\ \ \ \ \ \forall i. }[/math]

The decomposition of [math]\displaystyle{ \mathcal{S} }[/math] into the above minimal generating set determines that the code requires [math]\displaystyle{ s }[/math] ancilla qubits and [math]\displaystyle{ c }[/math] ebits. The code requires an ebit for every anticommuting pair in the minimal generating set. The simple reason for this requirement is that an ebit is a simultaneous [math]\displaystyle{ +1 }[/math]-eigenstate of the Pauli operators [math]\displaystyle{ \left\{ XX,ZZ\right\} }[/math]. The second qubit in the ebit transforms the anticommuting pair [math]\displaystyle{ \left\{ X,Z\right\} }[/math] into a commuting pair [math]\displaystyle{ \left\{ XX,ZZ\right\} }[/math]. The above decomposition also minimizes the number of ebits required for the code---it is an optimal decomposition.

We can partition the nonabelian group [math]\displaystyle{ \mathcal{S} }[/math] into two subgroups: the isotropic subgroup [math]\displaystyle{ \mathcal{S}_{I} }[/math] and the entanglement subgroup [math]\displaystyle{ \mathcal{S}_{E} }[/math]. The isotropic subgroup [math]\displaystyle{ \mathcal{S}_{I} }[/math] is a commuting subgroup of [math]\displaystyle{ \mathcal{S} }[/math] and thus corresponds to ancilla qubits:

[math]\displaystyle{ \mathcal{S}_{I}=\left\{ \bar{Z}_{1},\ldots,\bar{Z}_{s}\right\} }[/math].

The elements of the entanglement subgroup [math]\displaystyle{ \mathcal{S}_{E} }[/math] come in anticommuting pairs and thus correspond to ebits:

[math]\displaystyle{ \mathcal{S}_{E}=\left\{ \bar{Z}_{s+1},\ldots,\bar{Z}_{s+c},\bar{X}_{s+1},\ldots,\bar{X}_{s+c}\right\} }[/math].

Entanglement-assisted stabilizer code error correction conditions

The two subgroups [math]\displaystyle{ \mathcal{S}_{I} }[/math] and [math]\displaystyle{ \mathcal{S}_{E} }[/math] play a role in the error-correcting conditions for the entanglement-assisted stabilizer formalism. An entanglement-assisted code corrects errors in a set [math]\displaystyle{ \mathcal{E}\subset\Pi^{n} }[/math] if for all [math]\displaystyle{ E_{1},E_{2}\in\mathcal{E} }[/math],

[math]\displaystyle{ E_{1}^{\dagger}E_{2}\in\mathcal{S}_{I}\cup\left( \Pi^{n}-\mathcal{Z}\left( \left\langle \mathcal{S}_{I},\mathcal{S}_{E}\right\rangle \right) \right) . }[/math]

Operation

The operation of an entanglement-assisted code is as follows. The sender performs an encoding unitary on her unprotected qubits, ancilla qubits, and her half of the ebits. The unencoded state is a simultaneous +1-eigenstate of the following Pauli operators:

[math]\displaystyle{ \left\{ Z_{1},\ldots,Z_{s}, Z_{s+1}|Z_{1},\ldots,Z_{s+c}|Z_{c}, X_{s+1}|X_{1},\ldots,X_{s+c}|X_{c} \right\} . }[/math]

The Pauli operators to the right of the vertical bars indicate the receiver's half of the shared ebits. The encoding unitary transforms the unencoded Pauli operators to the following encoded Pauli operators:

[math]\displaystyle{ \left\{ \bar{Z}_{1},\ldots,\bar{Z}_{s}, \bar{Z}_{s+1}|Z_{1},\ldots,\bar{Z}_{s+c}|Z_{c}, \bar{X}_{s+1}|X_{1},\ldots,\bar{X}_{s+c}|X_{c} \right\} . }[/math]

The sender transmits all of her qubits over the noisy quantum channel. The receiver then possesses the transmitted qubits and his half of the ebits. He measures the above encoded operators to diagnose the error. The last step is to correct the error.

Rate of an entanglement-assisted code

We can interpret the rate of an entanglement-assisted code in three different ways (Wilde and Brun 2007b). Suppose that an entanglement-assisted quantum code encodes [math]\displaystyle{ k }[/math] information qubits into [math]\displaystyle{ n }[/math] physical qubits with the help of [math]\displaystyle{ c }[/math] ebits.

  • The entanglement-assisted rate assumes that entanglement shared between sender and receiver is free. Bennett et al. make this assumption when deriving the entanglement assisted capacity of a quantum channel for sending quantum information. The entanglement-assisted rate is [math]\displaystyle{ k/n }[/math] for a code with the above parameters.
  • The trade-off rate assumes that entanglement is not free and a rate pair determines performance. The first number in the pair is the number of noiseless qubits generated per channel use, and the second number in the pair is the number of ebits consumed per channel use. The rate pair is [math]\displaystyle{ \left( k/n,c/n\right) }[/math] for a code with the above parameters. Quantum information theorists have computed asymptotic trade-off curves that bound the rate region in which achievable rate pairs lie. The construction for an entanglement-assisted quantum block code minimizes the number [math]\displaystyle{ c }[/math] of ebits given a fixed number [math]\displaystyle{ k }[/math] and [math]\displaystyle{ n }[/math] of respective information qubits and physical qubits.
  • The catalytic rate assumes that bits of entanglement are built up at the expense of transmitted qubits. A noiseless quantum channel or the encoded use of noisy quantum channel are two different ways to build up entanglement between a sender and receiver. The catalytic rate of an [math]\displaystyle{ \left[ n,k;c\right] }[/math] code is [math]\displaystyle{ \left( k-c\right) /n }[/math].

Which interpretation is most reasonable depends on the context in which we use the code. In any case, the parameters [math]\displaystyle{ n }[/math], [math]\displaystyle{ k }[/math], and [math]\displaystyle{ c }[/math] ultimately govern performance, regardless of which definition of the rate we use to interpret that performance.

Example of an entanglement-assisted code

We present an example of an entanglement-assisted code that corrects an arbitrary single-qubit error (Brun et al. 2006). Suppose the sender wants to use the quantum error-correcting properties of the following nonabelian subgroup of [math]\displaystyle{ \Pi^{4} }[/math]:

[math]\displaystyle{ \begin{array} [c]{cccc} Z & X & Z & I\\ Z & Z & I & Z\\ X & Y & X & I\\ X & X & I & X \end{array} }[/math]

The first two generators anticommute. We obtain a modified third generator by multiplying the third generator by the second. We then multiply the last generator by the first, second, and modified third generators. The error-correcting properties of the generators are invariant under these operations. The modified generators are as follows:

[math]\displaystyle{ \begin{array} [c]{cccccc} g_{1} & = & Z & X & Z & I\\ g_{2} & = & Z & Z & I & Z\\ g_{3} & = & Y & X & X & Z\\ g_{4} & = & Z & Y & Y & X \end{array} }[/math]

The above set of generators have the commutation relations given by the fundamental theorem of symplectic geometry:

[math]\displaystyle{ \left\{ g_{1},g_{2}\right\} =\left[ g_{1},g_{3}\right] =\left[ g_{1},g_{4}\right] =\left[ g_{2},g_{3}\right] =\left[ g_{2},g_{4}\right] =\left[ g_{3},g_{4}\right] =0. }[/math]

The above set of generators is unitarily equivalent to the following canonical generators:

[math]\displaystyle{ \begin{array} [c]{cccc} X & I & I & I\\ Z & I & I & I\\ I & Z & I & I\\ I & I & Z & I \end{array} }[/math]

We can add one ebit to resolve the anticommutativity of the first two generators and obtain the canonical stabilizer:

[math]\displaystyle{ \begin{array} [c]{c} X\\ Z\\ I\\ I \end{array} \left\vert \begin{array} [c]{cccc} X & I & I & I\\ Z & I & I & I\\ I & Z & I & I\\ I & I & Z & I \end{array} \right. }[/math]

The receiver Bob possesses the qubit on the left and the sender Alice possesses the four qubits on the right. The following state is an eigenstate of the above stabilizer

[math]\displaystyle{ \left\vert \Phi^{+}\right\rangle ^{BA}\left\vert 00\right\rangle ^{A}\left\vert \psi\right\rangle ^{A}. }[/math]

where [math]\displaystyle{ \left\vert \psi\right\rangle ^{A} }[/math] is a qubit that the sender wants to encode. The encoding unitary then rotates the canonical stabilizer to the following set of globally commuting generators:

[math]\displaystyle{ \begin{array} [c]{c} X\\ Z\\ I\\ I \end{array} \left\vert \begin{array} [c]{cccc} Z & X & Z & I\\ Z & Z & I & Z\\ Y & X & X & Z\\ Z & Y & Y & X \end{array} \right. }[/math]

The receiver measures the above generators upon receipt of all qubits to detect and correct errors.

Encoding algorithm

We continue with the previous example. We detail an algorithm for determining an encoding circuit and the optimal number of ebits for the entanglement-assisted code---this algorithm first appeared in the appendix of (Wilde and Brun 2007a) and later in the appendix of (Shaw et al. 2008). The operators in the above example have the following representation as a binary matrix (See the stabilizer code article):

[math]\displaystyle{ H=\left[ \left. \begin{array} [c]{cccc} 1 & 0 & 1 & 0\\ 1 & 1 & 0 & 1\\ 0 & 1 & 0 & 0\\ 0 & 0 & 0 & 0 \end{array} \right\vert \begin{array} [c]{cccc} 0 & 1 & 0 & 0\\ 0 & 0 & 0 & 0\\ 1 & 1 & 1 & 0\\ 1 & 1 & 0 & 1 \end{array} \right] . }[/math]

Call the matrix to the left of the vertical bar the "[math]\displaystyle{ Z }[/math] matrix" and the matrix to the right of the vertical bar the "[math]\displaystyle{ X }[/math] matrix."

The algorithm consists of row and column operations on the above matrix. Row operations do not affect the error-correcting properties of the code but are crucial for arriving at the optimal decomposition from the fundamental theorem of symplectic geometry. The operations available for manipulating columns of the above matrix are Clifford operations. Clifford operations preserve the Pauli group [math]\displaystyle{ \Pi^{n} }[/math] under conjugation. The CNOT gate, the Hadamard gate, and the Phase gate generate the Clifford group. A CNOT gate from qubit [math]\displaystyle{ i }[/math] to qubit [math]\displaystyle{ j }[/math] adds column [math]\displaystyle{ i }[/math] to column [math]\displaystyle{ j }[/math] in the [math]\displaystyle{ X }[/math] matrix and adds column [math]\displaystyle{ j }[/math] to column [math]\displaystyle{ i }[/math] in the [math]\displaystyle{ Z }[/math] matrix. A Hadamard gate on qubit [math]\displaystyle{ i }[/math] swaps column [math]\displaystyle{ i }[/math] in the [math]\displaystyle{ Z }[/math] matrix with column [math]\displaystyle{ i }[/math] in the [math]\displaystyle{ X }[/math] matrix and vice versa. A phase gate on qubit [math]\displaystyle{ i }[/math] adds column [math]\displaystyle{ i }[/math] in the [math]\displaystyle{ X }[/math] matrix to column [math]\displaystyle{ i }[/math] in the [math]\displaystyle{ Z }[/math] matrix. Three CNOT gates implement a qubit swap operation. The effect of a swap on qubits [math]\displaystyle{ i }[/math] and [math]\displaystyle{ j }[/math] is to swap columns [math]\displaystyle{ i }[/math] and [math]\displaystyle{ j }[/math] in both the [math]\displaystyle{ X }[/math] and [math]\displaystyle{ Z }[/math] matrix.

The algorithm begins by computing the symplectic product between the first row and all other rows. We emphasize that the symplectic product here is the standard symplectic product. Leave the matrix as it is if the first row is not symplectically orthogonal to the second row or if the first row is symplectically orthogonal to all other rows. Otherwise, swap the second row with the first available row that is not symplectically orthogonal to the first row. In our example, the first row is not symplectically orthogonal to the second so we leave all rows as they are.

Arrange the first row so that the top left entry in the [math]\displaystyle{ X }[/math] matrix is one. A CNOT, swap, Hadamard, or combinations of these operations can achieve this result. We can have this result in our example by swapping qubits one and two. The matrix becomes

[math]\displaystyle{ \left[ \left. \begin{array} [c]{cccc} 0 & 1 & 1 & 0\\ 1 & 1 & 0 & 1\\ 1 & 0 & 0 & 0\\ 0 & 0 & 0 & 0 \end{array} \right\vert \begin{array} [c]{cccc} 1 & 0 & 0 & 0\\ 0 & 0 & 0 & 0\\ 1 & 1 & 1 & 0\\ 1 & 1 & 0 & 1 \end{array} \right] . }[/math]

Perform CNOTs to clear the entries in the [math]\displaystyle{ X }[/math] matrix in the top row to the right of the leftmost entry. These entries are already zero in this example so we need not do anything. Proceed to the clear the entries in the first row of the [math]\displaystyle{ Z }[/math] matrix. Perform a phase gate to clear the leftmost entry in the first row of the [math]\displaystyle{ Z }[/math] matrix if it is equal to one. It is equal to zero in this case so we need not do anything. We then use Hadamards and CNOTs to clear the other entries in the first row of the [math]\displaystyle{ Z }[/math] matrix.

We perform the above operations for our example. Perform a Hadamard on qubits two and three. The matrix becomes

[math]\displaystyle{ \left[ \left. \begin{array} [c]{cccc} 0 & 0 & 0 & 0\\ 1 & 0 & 0 & 1\\ 1 & 1 & 1 & 0\\ 0 & 1 & 0 & 0 \end{array} \right\vert \begin{array} [c]{cccc} 1 & 1 & 1 & 0\\ 0 & 1 & 0 & 0\\ 1 & 0 & 0 & 0\\ 1 & 0 & 0 & 1 \end{array} \right] . }[/math]

Perform a CNOT from qubit one to qubit two and from qubit one to qubit three. The matrix becomes

[math]\displaystyle{ \left[ \left. \begin{array} [c]{cccc} 0 & 0 & 0 & 0\\ 1 & 0 & 0 & 1\\ 1 & 1 & 1 & 0\\ 1 & 1 & 0 & 0 \end{array} \right\vert \begin{array} [c]{cccc} 1 & 0 & 0 & 0\\ 0 & 1 & 0 & 0\\ 1 & 1 & 1 & 0\\ 1 & 1 & 1 & 1 \end{array} \right] . }[/math]

The first row is complete. We now proceed to clear the entries in the second row. Perform a Hadamard on qubits one and four. The matrix becomes

[math]\displaystyle{ \left[ \left. \begin{array} [c]{cccc} 1 & 0 & 0 & 0\\ 0 & 0 & 0 & 0\\ 1 & 1 & 1 & 0\\ 1 & 1 & 0 & 1 \end{array} \right\vert \begin{array} [c]{cccc} 0 & 0 & 0 & 0\\ 1 & 1 & 0 & 1\\ 1 & 1 & 1 & 0\\ 1 & 1 & 1 & 0 \end{array} \right] . }[/math]

Perform a CNOT from qubit one to qubit two and from qubit one to qubit four. The matrix becomes

[math]\displaystyle{ \left[ \left. \begin{array} [c]{cccc} 1 & 0 & 0 & 0\\ 0 & 0 & 0 & 0\\ 0 & 1 & 1 & 0\\ 1 & 1 & 0 & 1 \end{array} \right\vert \begin{array} [c]{cccc} 0 & 0 & 0 & 0\\ 1 & 0 & 0 & 0\\ 1 & 0 & 1 & 1\\ 1 & 0 & 1 & 1 \end{array} \right] . }[/math]

The first two rows are now complete. They need one ebit to compensate for their anticommutativity or their nonorthogonality with respect to the symplectic product.

Now we perform a "Gram-Schmidt orthogonalization" with respect to the symplectic product. Add row one to any other row that has one as the leftmost entry in its [math]\displaystyle{ Z }[/math] matrix. Add row two to any other row that has one as the leftmost entry in its [math]\displaystyle{ X }[/math] matrix. For our example, we add row one to row four and we add row two to rows three and four. The matrix becomes

[math]\displaystyle{ \left[ \left. \begin{array} [c]{cccc} 1 & 0 & 0 & 0\\ 0 & 0 & 0 & 0\\ 0 & 1 & 1 & 0\\ 0 & 1 & 0 & 1 \end{array} \right\vert \begin{array} [c]{cccc} 0 & 0 & 0 & 0\\ 1 & 0 & 0 & 0\\ 0 & 0 & 1 & 1\\ 0 & 0 & 1 & 1 \end{array} \right] . }[/math]

The first two rows are now symplectically orthogonal to all other rows per the fundamental theorem of symplectic geometry. We proceed with the same algorithm on the next two rows. The next two rows are symplectically orthogonal to each other so we can deal with them individually. Perform a Hadamard on qubit two. The matrix becomes

[math]\displaystyle{ \left[ \left. \begin{array} [c]{cccc} 1 & 0 & 0 & 0\\ 0 & 0 & 0 & 0\\ 0 & 0 & 1 & 0\\ 0 & 0 & 0 & 1 \end{array} \right\vert \begin{array} [c]{cccc} 0 & 0 & 0 & 0\\ 1 & 0 & 0 & 0\\ 0 & 1 & 1 & 1\\ 0 & 1 & 1 & 1 \end{array} \right] . }[/math]

Perform a CNOT from qubit two to qubit three and from qubit two to qubit four. The matrix becomes

[math]\displaystyle{ \left[ \left. \begin{array} [c]{cccc} 1 & 0 & 0 & 0\\ 0 & 0 & 0 & 0\\ 0 & 1 & 1 & 0\\ 0 & 1 & 0 & 1 \end{array} \right\vert \begin{array} [c]{cccc} 0 & 0 & 0 & 0\\ 1 & 0 & 0 & 0\\ 0 & 1 & 0 & 0\\ 0 & 1 & 0 & 0 \end{array} \right] . }[/math]

Perform a phase gate on qubit two:

[math]\displaystyle{ \left[ \left. \begin{array} [c]{cccc} 1 & 0 & 0 & 0\\ 0 & 0 & 0 & 0\\ 0 & 0 & 1 & 0\\ 0 & 0 & 0 & 1 \end{array} \right\vert \begin{array} [c]{cccc} 0 & 0 & 0 & 0\\ 1 & 0 & 0 & 0\\ 0 & 1 & 0 & 0\\ 0 & 1 & 0 & 0 \end{array} \right] . }[/math]

Perform a Hadamard on qubit three followed by a CNOT from qubit two to qubit three:

[math]\displaystyle{ \left[ \left. \begin{array} [c]{cccc} 1 & 0 & 0 & 0\\ 0 & 0 & 0 & 0\\ 0 & 0 & 0 & 0\\ 0 & 0 & 0 & 1 \end{array} \right\vert \begin{array} [c]{cccc} 0 & 0 & 0 & 0\\ 1 & 0 & 0 & 0\\ 0 & 1 & 0 & 0\\ 0 & 1 & 1 & 0 \end{array} \right] . }[/math]

Add row three to row four and perform a Hadamard on qubit two:

[math]\displaystyle{ \left[ \left. \begin{array} [c]{cccc} 1 & 0 & 0 & 0\\ 0 & 0 & 0 & 0\\ 0 & 1 & 0 & 0\\ 0 & 0 & 0 & 1 \end{array} \right\vert \begin{array} [c]{cccc} 0 & 0 & 0 & 0\\ 1 & 0 & 0 & 0\\ 0 & 0 & 0 & 0\\ 0 & 0 & 1 & 0 \end{array} \right] . }[/math]

Perform a Hadamard on qubit four followed by a CNOT from qubit three to qubit four. End by performing a Hadamard on qubit three:

[math]\displaystyle{ \left[ \left. \begin{array} [c]{cccc} 1 & 0 & 0 & 0\\ 0 & 0 & 0 & 0\\ 0 & 1 & 0 & 0\\ 0 & 0 & 1 & 0 \end{array} \right\vert \begin{array} [c]{cccc} 0 & 0 & 0 & 0\\ 1 & 0 & 0 & 0\\ 0 & 0 & 0 & 0\\ 0 & 0 & 0 & 0 \end{array} \right] . }[/math]

The above matrix now corresponds to the canonical Pauli operators. Adding one half of an ebit to the receiver's side gives the canonical stabilizer whose simultaneous +1-eigenstate is the above state. The above operations in reverse order take the canonical stabilizer to the encoded stabilizer.

References