Quantenfehlerkorrektur

Art von Fehlerkorrekturverfahren

Quantenfehlerkorrektur wird in der Quanteninformatik benutzt, um Quanteninformation vor Fehlern infolge von Dekohärenz und Quantenrauschen zu schützen. Quantenfehlerkorrekturen sind grundlegend beim Ausführen von fehlertoleranten Quantenberechnungen, welche nicht nur Störungen in gespeicherter Quanteninformation beheben, sondern auch fehlerhafte Quantengatter, sowie auch fehlerhafte Messungen.

Allgemeines

Bearbeiten

Quantencomputer sind besonders fehleranfällig aufgrund Dekohärenz und anderer Ursachen. Die DiVincenzo-Kriterien für die Architektur von Quantencomputern betonen die Notwendigkeit einer Quantenfehlerkorrektur, um eine zuverlässige und fehlertorante Berechnung sicherzustellen.[1] Ohne Fehlerkorrektur wären Quantencomputer wiederum auch ohne großen Nutzen, da die Fehleranfälligkeit hoch ist.[2]

Die klassische Fehlerkorrektur verwendet Redundanz.[3] Der einfachste Weg ist, die Information mehrfach zu speichern, und wenn diese Kopien sich später unterscheiden, die Mehrheit auszuwählen. Angenommen, wir kopieren ein Bit dreimal. Wir nehmen weiter an, dass eine Störung den Zustand der drei Bits so verändert, dass ein Bit den Wert Null annimmt, aber die anderen beiden den Wert Eins. Wir setzen auch voraus, dass Störungen unabhängig sind und mit einer gewissen Wahrscheinlichkeit p auftreten. Es ist sehr wahrscheinlich, dass der Fehler bei einem Bit liegt und die gesendete Nachricht drei Einsen enthält. Es besteht auch eine Wahrscheinlichkeit, dass ein Doppelfehler auftritt und die gesendete Nachricht drei Nullen enthält, aber dieses Ergebnis ist weniger wahrscheinlich als das erste.

Quanteninformation zu kopieren, ist laut dem No-Cloning-Theorem nicht möglich und stellt daher eine Einschränkung bei der Formulierung einer Theorie der Quantenfehlerkorrektur dar. Aber es ist möglich, die Information von einem Qubit auf ein verschränktes System von mehreren Qubits zu übertragen.[4] Peter Shor entdeckte 1995 als Erster diese Methode, indem er einen Code zur Quantenfehlerkorrektur entwickelte, der die Information von einem Qubit auf ein verschränktes System von neun Qubits übertrug.[5] Ein Code, basierend auf Quantenfehlerkorrektur, schützt Quanteninformation gegen Fehler von begrenzter Form. Shor's Code bedeutete einen signifikanten Durchbruch in der Quanteninformatik, der zeigte, dass Quanteninformationen in einer systematischen Weise gegen Fehler geschützt werden konnten und legte die Grundlagen für die sich entwickelnde Quantenfehlerkorrektur.[6]

Klassische fehlerkorrigierende Codes verwenden eine Syndrom-Messung, um festzustellen, welcher Fehler einen verschlüsselten Zustand zerstört. Der Fehler wird dann rückgängig gemacht, indem eine durch das Syndrom bestimmte, korrigierende Operation angewendet wird.[3] Quantenfehlerkorrektur verwendet auch eine Syndrom-Messung. Allerdings muss nun, anders als im klassischen Fall, sichergestellt werden, dass sich aus der Syndrommessung keine Information über die kodierte Quanteninformation entnehmen lässt, sondern nur über das Vorliegen und die Art eines Fehlers. Eine Syndrom-Messung kann (für eine begrenzte Menge von mit dem verwendeten Code korrigierbaren Fehlern) bestimmen, ob ein Qubit beschädigt wurde, und wenn ja, welches beschädigt wurde. Darüber hinaus sagt uns das Ergebnis der Operation nicht nur, welches physikalische Qubit betroffen war, sondern auch, auf welchem der möglichen Wege es betroffen war. Letzteres ist auf den ersten Blick überraschend, da es nur eine endliche, diskrete Menge von Syndromen gibt, aber ein Kontinuum von unendlich vielen möglichen Fehleroperationen. Ein ähnliches Problem tritt in klassischen Analogrechnern auf, in denen das Auftreten eines Kontinuums an möglichen Fehlern dazu führt, dass alle Vorteile, die ein fehlerfreier Analogrechner gegenüber einem Digitalrechner hätte, verloren gehen.[7] Die Quantenfehlerkorrektur macht sich bei der Messung des Syndroms den projektiven Effekt jeder Quantenmessung zunutze. Die Syndrommessung diskretisiert das Kontinuum an möglichen Fehlern, indem sie den Zustand des kodierten Qubits entweder auf den fehlerfreien Unterraum oder auf den Unterraum projiziert, der zu einem bestimmten der korrigierbaren Fehler (typischerweise eine Kombination von Bitflip- und Phasenflip-Fehlern an bestimmten Qubits, den sogenannten „Pauli-Fehlern“, da sie sich durch Anwendung der Pauli-Matrizen   auf ein oder mehrere Qubits beschreiben lassen) gehört. Die Syndrom-Messung „zwingt“ das Qubit, sich für einen speziellen „Pauli-Fehler“ zu „entscheiden“, und das Messergebnis sagt, für welchen. Da die Pauli-Fehler alle umkehrbar sind (durch die erneute Anwendung derselben Pauli-Matrizen auf dieselben Qubits), erlaubt die Kenntnis des Syndroms nun, den Fehler zu korrigieren.[8]

Die Syndrom-Messung sagt uns so viel wie möglich über den ereigneten Fehler, aber überhaupt nichts über den Wert, der im Qubit gespeichert ist – anders würde die Messung jegliche Superposition des Qubits und anderer Qubits im Quantencomputer zerstören.

Der Bit-Flip-Code

Bearbeiten

Für klassische Bits kann ein Wiederholungscode angewandt werden, da Bits leicht zu messen und wiederherzustellen sind. Für Qubits ist dies hingegen, aufgrund des No-Cloning-Theorems, welches die Erzeugung von identischen Kopien eines beliebigen Quantenzustandes verbietet, nicht mehr möglich, denn ein einzelnes Qubit in einem unbekannten Zustand kann nicht dreimal kopiert werden wie im oberen Beispiel verlangt, und jegliche Messung würde Information im Qubit verändern. Dennoch gibt es für Quantencomputer Methoden, ein Qubit gegen Bit-Flip-Fehler zu schützen. Die einfachste ist der 3-Qubit-Bit-Flip-Code,[9] der aber schon die allgemeine Vorgehensweise illustriert: es werden verschränkte Zustände verwendet, um das Qubit zu kodieren und Syndrommessungen, die blind sind für den Zustand des kodierten Qubits, um den Fehler zu entdecken. Damit wird das gleiche Ergebnis erreicht wie mit dem Wiederholungscode klassische Bits: ein Bit-Flip-Fehler pro logischem (Qu)Bit kann korrigiert werden.

Der Coderaum wird aufgespannt durch die zwei 3-Qubit-Zustände   und  . Der Zustand   eines Qubits kann mittels zweier CNOT-Gatter in den Coderaum geschrieben werden. Dazu verwendet man zwei weitere, im Zustand   präparierte Qubits und wendet dann ein CNOT auf Qubit 1 und 2 und dann ein weiteres CNOT auf Qubit 1 und 3 an, wobei jeweils Qubit 1 das Kontroll-Qubit ist.

 
Quantenschaltung des Bit Flip Code

Das Ergebnis sieht folgendermaßen aus:   Dies ist ein Zustand von drei Qubits, der —für  — drei verschränkte Qubits beschreibt und verschieden ist vom dreifachen „Klon“ des Zustands  . Um das Vorgehen zur Fehlerkorrektur zu illustrieren, betrachtet man beispielhaft den Fall, dass das erste Qubit einem Bit-Flip-Fehler unterliegt. Das Ergebnis würde folgendermaßen aussehen:  . Um die Umkehrung bei irgendeinem der drei möglichen Qubits festzustellen, benötigt man eine Syndromdiagnose, die einerseits feststellen muss, dass das erste Bit geflippt wurde (beziehungsweise, dass nichts geflippt wurde, wenn das Qubit weiterhin im Zustand   ist) und andererseits keine Information über den Zustand selbst liefert (d. h., unabhängig ist von  ). Dies kann durch eine Messung erreicht werden, welche durch die folgenden vier, paarweise orthogonalen Projektionsoperatoren definiert ist:

 
 
 
 

Hier projiziert   auf den Coderaum und liefert somit immer das Ergebnis 1 für jeden Zustand der Form  , insbesondere für  . Dagegen projiziert   auf den Unterraum, in dem das erste Qubit geflippt wurde und entsprechend   für die anderen beiden Qubits. Für den Zustand   ergeben sich damit die folgenden Resultate:

 
 
 
 

Das Messresultat („Syndrom“)   signalisiert, somit, dass das zweite Qubit einem Bit-Flip unterlegen ist. Durch Anwendung eines Nicht-Gatters auf das Qubit 1 kann der Fehler dann korrigiert werden:  . Wenn allerdings zwei Bit-Flip-Fehler passieren, bevor das Syndrom gemessen wird, dann funktioniert der Code nicht mehr, denn zwei Bit-Flips an verschiedenen Qubits produzieren dasselbe Syndrom wie ein Bitflip am dritten Qubit und die Korrekturoperation führt dann zu einem Bit-Flip-Fehler des logischen Qubits. Für die Korrektur von mehr als einem Fehler ist (wie auch beim klassischen Wiederholungscode) mehr Redundanz nötig.

Der Sign-Flip-Code

Bearbeiten
 
Quantenschaltung des Sign Flip Codes

Der Bit Flip ist die einzige Art Fehler in klassischen Computern, in Quantencomputern kann jedoch außerdem noch ein Sign Flip auftreten. Um mit dieser Art Fehler umzugehen, verwendet man den Sign Flip Code. Durch die Übertragung in einem Kanal kann das Vorzeichen zwischen   und   ebenfalls umgekehrt werden. Zum Beispiel ein Qubit im Zustand   möge durch Umkehrung des Vorzeichens in   umgewandelt werden.

Der Originalzustand des Qubits

 

wird in den Zustand

 

umgewandelt.

Die Verbesserung des Fehlers nach dem Sign Flip Code ist identisch mit dem Bit Flip Code.

Der Shor-Code

Bearbeiten
 
Quantenschaltung des Shor Codes mit CNOT and Hadamard Gattern

Der nach Peter Shor benannte Code ist ein Quantenfehlercode, der ein logisches Qubit in neun physischen Qubits codiert und die Prinzipien der klassischen Fehlerkorrektur und der Quantenmechanik kombiniert. Er benutzt eine Reihe von kontrollierten Operationen nach einem spezifischen Muster. Das Muster erlaubt den Code, sowohl Bits Flips als auch Sign Flips Fehler zu erkennen, ohne das logische Qubit direkt zu messen, sondern lediglich die zusätzlichen Qubits.[6] Der Code ist eine Kombination des Sign-Flip-Codes und des Bit-Flip-Codes.[10]

Der Fehlerkorrektur-Code auf Kanäle angewandt, möge entweder das Bit umkehren oder das Vorzeichen umkehren. Es ist ebenso möglich, beide Codes in einem Code zu kombinieren. Der Shor Code ist nur eine Methode, welche beliebige Qubit-Fehler korrigieren kann.

Das erste, vierte und siebte Qubit sind für den Sign Flip Code, während die Dreier-Gruppen (1,2,3), (4,5,6), und (7,8,9) für den Bit Flip Code ausgelegt sind. Mit dem Shor Code wird der Zustand eines Qubits   in ein Produkt von 9 Qubits   transformiert, wobei

 
 

Wenn ein Bit-Flip-Fehler an einem Qubit auftritt, wird eine Syndrom-Analyse an jeder Gruppe von Zuständen (1,2,3), (4,5,6), und (7,8,9), ausgeführt und der Fehler korrigiert.

Wenn die 3-Bit-Flip-Gruppen (1,2,3), (4,5,6), und (7,8,9) als drei Eingänge betrachtet werden, dann kann der Shor-Code-Schaltkreis auf einen Sign Flip Code reduziert werden. Das heißt, der Shor Code kann auch Sign-Flip-Fehler an einem einzelnen Qubit reparieren.[5] Der Shor Code kann auch jeden beliebigen Fehler (Bit Flip und Sign Flip) an einem einzelnen Qubit korrigieren. Wenn ein beliebiger Fehler eine beliebige unitäre Transformation   ist, welche an einem Qubit einwirkt

 
  ist der Originalzustand des einzelnen Qubits, welches betroffen ist.   kann beschrieben werden in der Form
 

wobei  , , , und   komplexe Koeffizienten sind,   ist die Identität, und die Pauli-Matrizen sind gegeben durch

 
 
 

Die Pauli-Matrizen sind eine Gruppe von 2×2 hermiteschen und unitären Matrizen. Ist  , dann heißt das, der Zustand ist unverändert. Wenn   ist, dann hat sich ein Bit-Flip-Fehler im Kanal ereignet, wenn   ist, dann muss sich das Vorzeichen umgekehrt haben, und laut   beides, ein Bit Flip und ein Sign Flip. Dann wird die Fehlerkorrektur wie oben den Fehler korrigieren. Aber der Shor Code funktioniert nur im Falle eines 1-Qubit-Fehlers.

Der Shor Code wurde in vielen Quantensystemen implementiert und dient als Komponente für komplexere Fehlerkorrekturcodes und fehlertolerante Architekturen und deren Weiterentwicklung. Die Implementierung erfordert eine präzise Kontrolle von Multiplen Qubits und komplexe Fehlermessungen. Im Gegenzug bietet der Code Robustheit. Der hohe Overhead in der Redundanz von 9 physikalischen Qubits für jedes logische Qubit bedeutet eine Herausforderung für die Skalierbarkeitsbemühungen.[6]

Mit der Zeit sind von Forschern verschiedene Codemodelle entwickelt worden.

Diese Codes erlauben allerdings Quantencomputing mit beliebiger Länge und sind Inhalt des Grenzwert-Theorems, begründet von Michael Ben-Or und Dorit Aharonov, welches behauptet, dass man alle Fehler korrigieren kann[17], wenn man Quanten Codes verkettet, wie die CSS-Codes, das heißt jedes logische Qubit mit demselben Code wieder verschlüsseln, und so weiter, auf logarithmisch vielen Stufen—„liefert“ die Fehlerrate von individuellen Quantengattern unter einem bestimmten Grenzwert; würde man hingegen für größere Fehlerraten versuchen, die Syndrome zu messen und Fehler zu korrigieren, würden mehr neue Fehler einfließen als korrigiert werden.

2004 wurde von Emanuel Knill[18] für diesen Grenzwert geschätzt, dass er bei 1–3 % liegen könnte, sofern ausreichend viele Qubits vorhanden sind.

Experimentelle Realisierung

Bearbeiten

2022 haben Forscher einen fehlertoleranten universellen Satz von Gattern für zwei logische Qubits in einem Quantencomputer mit 16 gefangenen Ionen demonstriert. Die logischen Qubits wurden auf jeweils sieben Atome verteilt. Auf diesen haben die Physiker zwei Rechengatter realisiert, die für einen universellen Gattersatz notwendig sind: ein CNOT-Gatter und ein logisches T-Gatter.[19]

Literatur

Bearbeiten
  • D. A. Lidar, T. A. Brun: Quantum Error Correction. Cambridge University Press, Cambridge MA 2013, ISBN 978-0-521-89787-7 (eingeschränkte Vorschau in der Google-Buchsuche).
  • S. J. Devitt, W. J. Munro, K. Nemoto: Quantum error correction for beginners. In: Reports on Progress in Physics. Band 76, Nr. 7, 20. Juni 2013.arxiv:0905.2794
  • Daniel Gottesman: Stabilizer Codes and Quantum Error Correction. Ph.D. Thesis. California Institute of Technology, Pasadena 1997, arxiv:quant-ph/9705052.
  • John Preskill: Fault-tolerant quantum computation. In: Quantum Physics. 19. Dezember 2013, arxiv:quant-ph/9712048.
Bearbeiten

Einzelnachweise

Bearbeiten
  1. David P. DiVincenzo: Topics in Quantum Computers. In: L. Kouwenhoven, G. Schoen und L. L. Sohn (Hrsg.): Mesoscopic Electron Transport. NATO ASI Series E. Nr. 345. Kluwer Academic Publishers, Dordrecht 1997, S. 657, arxiv:cond-mat/9612126v2 (englisch).
  2. Sebastian Smerat: Quantenfehlerkorrektur (PDF; 158 kB) 14. Juli 2005.
  3. a b A. M. Steane: A tutorial on quantum error correction. In: G. Casati, D. L. Shepelyansky, P. Zoller, G. Benenti (Hrsg.): Quantum Computers, Algorithms and Chaos (= Proceedings of the International School of Physics "Enrico Fermi"). Band 162, 2006, S. 1–32, doi:10.3254/978-1-61499-018-5-1 (ox.ac.uk [PDF; 282 kB]).
  4. Roland Wengenmayr: Superrechner für Spezialanwendungen Seite 2/2: Wie die Verschränkung der Qubits funktioniert In: Zeit Online 2. Juli 2012
  5. a b Peter W. Shor: Scheme for reducing decoherence in quantum computer memory. In: Physical Review A. Band 52, Nr. 4, Oktober 1995, S. R2493–R2496, doi:10.1103/PhysRevA.52.R2493 (miami.edu [PDF]).
  6. a b c Shor's Code In: QuEra Computing Inc. Glossary
  7. M. A. Nielsen, I. L. Chuang: Quantum Computation and Quantum Information. Cambridge University Press, Cambridge MA 2010, ISBN 978-1-107-00217-3, S. 163f (wordpress.com [PDF]).
  8. M. A. Nielsen, I. L. Chuang: Quantum Computation and Quantum Information. Cambridge University Press, Cambridge MA 2010, ISBN 978-1-107-00217-3, S. 435ff (wordpress.com [PDF]).
  9. M. A. Nielsen, I. L. Chuang: Quantum Computation and Quantum Information. Cambridge University Press, Cambridge MA 2010, ISBN 978-1-107-00217-3, S. 427–430 (wordpress.com [PDF]).
  10. M. A. Nielsen, I. L. Chuang: Quantum Computation and Quantum Information. Cambridge University Press, Cambridge MA 2010, ISBN 978-1-107-00217-3, S. 432–435 (wordpress.com [PDF]).
  11. Victor V. Albert, Philippe Faist: Steane code. In: Quantum Error Correction Zoo. 2023 (errorcorrectionzoo.org).
  12. Raymond Laflamme, Cesar Miquel, Juan Pablo Paz, W. H. Zurek: Perfect Quantum Error Correction Code. In: Phys. Rev. Lett. Band 77, 1996, S. 198, doi:10.1103/PhysRevLett.77.198, arxiv:quant-ph/9602019.
  13. Victor V. Albert, Philippe Faist: Five-qubit perfect code. In: Quantum Error Correction Zoo. 2023 (errorcorrectionzoo.org).
  14. D. Gottesman: A Class of Quantum Error-Correcting Codes Saturating the Quantum Hamming Bound. In: Phys. Rev. A. Band 54, 1996, S. 1862, doi:10.1103/PhysRevA.54.1862, arxiv:quant-ph/9604038.
  15. A. R. Calderbank u. a.: Quantum Error Correction and Orthogonal Geometry. In: Phys. Rev. Lett. Band 78, 1997, S. 405–408, doi:10.1103/PhysRevLett.78.405, arxiv:quant-ph/9605005.
  16. A. R. Calderbank u. a.: Quantum Error Correction via Codes over GF(4). In: IEEE Transactions on Information Theory. Band 44, Nr. 4, 1998, S. 1369–1387, doi:10.1109/18.681315, arxiv:quant-ph/9608006.
  17. D. Aharonov, M. Ben-Or: Fault-Tolerant Quantum Computation with Constant Error Rate. In: SIAM Journal on Computing. Band 38, Nr. 4, 1. Januar 2008, ISSN 0097-5397, S. 1207–1282, doi:10.1137/S0097539799359385, arxiv:quant-ph/9906129.
  18. E. Knill: Quantum computing with realistically noisy devices. In: Nature, Band 434, 2005, S. 39–44, arxiv:quant-ph/0410199 2004
  19. Lukas Postler, Sascha Heußen, Ivan Pogorelov, Manuel Rispler, Thomas Feldker, Michael Meth, Christian D. Marciniak, Roman Stricker, Martin Ringbauer, Rainer Blatt, Philipp Schindler, Markus Müller & Thomas Monz: Demonstration of fault-tolerant universal quantum gate operations. In: Nature, Band 605, 2022, S. 675–680, doi:10.1038/s41586-022-04721-1 arxiv:2111.12654 [quant-ph] 2021