Quantenfehlerkorrektur
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
BearbeitenQuantencomputer 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
BearbeitenFü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.
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
BearbeitenDer 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
BearbeitenDer 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]
Modelle
BearbeitenMit der Zeit sind von Forschern verschiedene Codemodelle entwickelt worden.
- Peter Shors 9-qubit-code, auch bekannt als der Shor-Code, verschlüsselt ein logisches Qubit in neun physikalische Qubits und kann beliebige Fehler an einem einzelnen Qubit korrigieren.
- Andrew Steane fand einen Code, der dasselbe mit 7 anstatt 9 Qubits macht (Steane-Code).[11]
- Raymond Laflamme fand eine Klasse von 5-Qubit Codes, welche dasselbe machen, und welche auch die Eigenschaft besitzen, fehlertolerant zu sein.[12][13]
- Eine Verallgemeinerung dieses Konzepts sind die CSS-Codes, benannt nach den Erfindern: Robert Calderbank, Peter Shor und Andrew Steane. Laut der Quanten-Hamming-Schranke, benötigt die Kodierung eines einzelnen logischen Qubits mit der Möglichkeit zur Korrektur beliebiger Ein-Qubit-Fehler ein Minimum von fünf physikalischen Qubits.
- Eine allgemeinere Klasse von Codes sind die Stabilizer-Codes, entdeckt von Daniel Gottesman,[14] und von Calderbank und Shor zusammen mit Eric Rains und Neil Sloane;[15][16] diese werden additive Codes genannt.
- Eine neuere Idee sind Alexei Kitajews Topologische Quantencodes und die allgemeinere Idee von topologischen Quantencomputern.
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
Bearbeiten2022 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.
Weblinks
Bearbeiten- Andrew M. Steane: A Tutorial on Quantum Error Correction In: G. Casati, D. L. Shepelyansky and P. Zoller (Hrsg.): Proceedings of the International School of Physics “Enrico Fermi”, course CLXII, “Quantum Computers, Algorithms and Chaos”, S. 1–32 (IOS Press, Amsterdam 2006).
- Björn Stein: Quantum Error Correction. Ludwig-Maximilians-Universität München, 2003 (Seminar im Hauptstudium Sommersemester 2003).
Einzelnachweise
Bearbeiten- ↑ 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).
- ↑ Sebastian Smerat: Quantenfehlerkorrektur (PDF; 158 kB) 14. Juli 2005.
- ↑ 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]).
- ↑ Roland Wengenmayr: Superrechner für Spezialanwendungen Seite 2/2: Wie die Verschränkung der Qubits funktioniert In: Zeit Online 2. Juli 2012
- ↑ 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]).
- ↑ a b c Shor's Code In: QuEra Computing Inc. Glossary
- ↑ 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]).
- ↑ 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]).
- ↑ 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]).
- ↑ 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]).
- ↑ Victor V. Albert, Philippe Faist: Steane code. In: Quantum Error Correction Zoo. 2023 (errorcorrectionzoo.org).
- ↑ 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.
- ↑ Victor V. Albert, Philippe Faist: Five-qubit perfect code. In: Quantum Error Correction Zoo. 2023 (errorcorrectionzoo.org).
- ↑ 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.
- ↑ 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.
- ↑ 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.
- ↑ 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.
- ↑ E. Knill: Quantum computing with realistically noisy devices. In: Nature, Band 434, 2005, S. 39–44, arxiv:quant-ph/0410199 2004
- ↑ 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